|
What this is
Other links
The source code
// $Header: /home/cvs/jakarta-jmeter/src/htmlparser/org/htmlparser/tests/scannersTests/ImageScannerTest.java,v 1.2 2004/02/11 02:16:58 woolfel Exp $
/*
* ====================================================================
* Copyright 2002-2004 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
// The developers of JMeter and Apache are greatful to the developers
// of HTMLParser for giving Apache Software Foundation a non-exclusive
// license. The performance benefits of HTMLParser are clear and the
// users of JMeter will benefit from the hard work the HTMLParser
// team. For detailed information about HTMLParser, the project is
// hosted on sourceforge at http://htmlparser.sourceforge.net/.
//
// HTMLParser was originally created by Somik Raha in 2000. Since then
// a healthy community of users has formed and helped refine the
// design so that it is able to tackle the difficult task of parsing
// dirty HTML. Derrick Oswald is the current lead developer and was kind
// enough to assist JMeter.
package org.htmlparser.tests.scannersTests;
import org.htmlparser.Node;
import org.htmlparser.Parser;
import org.htmlparser.scanners.ImageScanner;
import org.htmlparser.scanners.TableScanner;
import org.htmlparser.tags.ImageTag;
import org.htmlparser.tags.LinkTag;
import org.htmlparser.tags.TableColumn;
import org.htmlparser.tags.TableRow;
import org.htmlparser.tags.Tag;
import org.htmlparser.tags.data.TagData;
import org.htmlparser.tests.ParserTestCase;
import org.htmlparser.util.LinkProcessor;
import org.htmlparser.util.NodeIterator;
import org.htmlparser.util.ParserException;
public class ImageScannerTest extends ParserTestCase
{
public ImageScannerTest(String name)
{
super(name);
}
public void testDynamicRelativeImageScan() throws ParserException
{
createParser(
" | Find your match on Yahoo! Personals | |
| \n" + " advanced search | ||
| ||||||||
Shop \n",
"http://www.yahoo.com");
Node[] node = new Node[10];
// Register the image scanner
parser.addScanner(new ImageScanner("-i", new LinkProcessor()));
int i = 0;
Node thisNode;
for (NodeIterator e = parser.elements(); e.hasMoreNodes();)
{
thisNode = (Node) e.nextNode();
if (thisNode instanceof ImageTag)
node[i++] = thisNode;
}
assertEquals("Number of nodes identified should be 3", 3, i);
assertTrue(
"Node identified should be HTMLImageTag",
node[0] instanceof ImageTag);
ImageTag imageTag = (ImageTag) node[0];
assertEquals(
"Expected Image",
"http://us.a1.yimg.com/us.yimg.com/a/co/columbiahouse/4for49Freesh_230x33_redx2.gif",
imageTag.getImageURL());
ImageTag imageTag2 = (ImageTag) node[1];
assertEquals(
"Expected Image 2",
"http://us.i1.yimg.com/us.yimg.com/i/ligans/klgs/eet.gif",
imageTag2.getImageURL());
ImageTag imageTag3 = (ImageTag) node[2];
assertEquals(
"Expected Image 3",
"http://us.i1.yimg.com/us.yimg.com/i/ligans/klgs/ern.gif",
imageTag3.getImageURL());
}
/**
* Test case to reproduce bug reported by Annette
*/
public void testImageTagsFromYahooWithAllScannersRegistered()
throws ParserException
{
createParser(
"| "
+ " Air, Hotel, "
+ "Vacations, Cruises"
+ " | "
+ ""
+ " | "
+ ""
+ "Find your match on | "
+ "" + "Yahoo! Personals" + " "
+ "\n"
+ " | "
+ ""
+ " | ",
"http://www.cia.gov");
// Register the image scanner
parser.registerScanners();
parser.addScanner(new TableScanner(parser));
parseAndAssertNodeCount(1);
assertType("node should be", TableColumn.class, node[0]);
TableColumn col = (TableColumn) node[0];
Node node = col.children().nextNode();
assertType("node inside column", ImageTag.class, node);
ImageTag imageTag = (ImageTag) node;
// Get the data from the node
assertEquals(
"Image location",
"http://www.cia.gov/graphics/images_home2/cia_banners_template3_01.gif",
imageTag.getImageURL());
assertEquals(
"Alt Value",
"Central Intelligence Agency, Director of Central Intelligence",
imageTag.getAttribute("ALT"));
assertEquals("Width", "241", imageTag.getAttribute("WIDTH"));
assertEquals("Height", "49", imageTag.getAttribute("HEIGHT"));
}
public void testDirectRelativeLinks() throws ParserException
{
createParser(
" ",
"http://www.cybergeo.presse.fr/REVGEO/ttsavoir/joly.htm");
// Register the image scanner
parser.registerScanners();
parseAndAssertNodeCount(1);
assertTrue(
"Node identified should be HTMLImageTag",
node[0] instanceof ImageTag);
ImageTag imageTag = (ImageTag) node[0];
assertEquals(
"Image Location",
"http://www.cybergeo.presse.fr/images/lines/li065.jpg",
imageTag.getImageURL());
}
/**
* Based on a page submitted by Claude Duguay, the image tag has IMG SRC"somefile.jpg" - a missing equal
* to sign
*/
public void testMissingEqualTo() throws ParserException
{
createParser(
" |
|||
| ... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.