當前位置: 首頁>>代碼示例>>Java>>正文


Java CrawljaxConfigurationBuilder類代碼示例

本文整理匯總了Java中com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder的典型用法代碼示例。如果您正苦於以下問題:Java CrawljaxConfigurationBuilder類的具體用法?Java CrawljaxConfigurationBuilder怎麽用?Java CrawljaxConfigurationBuilder使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


CrawljaxConfigurationBuilder類屬於com.crawljax.core.configuration.CrawljaxConfiguration包,在下文中一共展示了CrawljaxConfigurationBuilder類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: main

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
public static void main(String[] args) {

		CrawljaxConfigurationBuilder builder =
		        CrawljaxConfiguration.builderFor("http://demo.crawljax.com/");
		builder.addPlugin(new OnNewStatePlugin() {

			@Override
			public void onNewState(CrawlerContext context, StateVertex newState) {
				// This will print the DOM when a new state is detected. You should see it in your
				// console.
				LOG.info("Found a new dom! Here it is:\n{}", context.getBrowser().getStrippedDom());
			}

			@Override
			public String toString() {
				return "Our example plugin";
			}
		});
		CrawljaxRunner crawljax = new CrawljaxRunner(builder.build());
		crawljax.call();
	}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:22,代碼來源:PluginExample.java

示例2: main

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
/**
 * Run this method to start the crawl.
 */
public static void main(String[] args) {
	CrawljaxConfigurationBuilder builder =
	        CrawljaxConfiguration.builderFor("http://demo.crawljax.com/");

	// Add the invariant that checks that the string isn't present.
	builder.crawlRules().addInvariant(
	        "Detect a string",
	        new NotRegexCondition(
	                "Invariants can be used to perform tests on the current state"));

	// This plugin will just print the error.
	builder.addPlugin(new OnInvariantViolationPlugin() {

		@Override
		public void onInvariantViolation(Invariant invariant, CrawlerContext context) {
			LOG.error("\n\n!!! Invariant {} violated !!!\n", invariant);
		}

	});

	CrawljaxRunner crawljax = new CrawljaxRunner(builder.build());
	crawljax.call();
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:27,代碼來源:InvariantExample.java

示例3: main

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
/**
 * Entry point
 */
public static void main(String[] args) {
	CrawljaxConfigurationBuilder builder = CrawljaxConfiguration.builderFor(URL);
	builder.crawlRules().insertRandomDataInInputForms(false);

	builder.crawlRules().click("a");
	builder.crawlRules().click("button");

	// except these
	builder.crawlRules().dontClick("a").underXPath("//DIV[@id='guser']");
	builder.crawlRules().dontClick("a").withText("Language Tools");

	// limit the crawling scope
	builder.setMaximumStates(MAX_NUMBER_STATES);
	builder.setMaximumDepth(MAX_DEPTH);

	builder.addPlugin(new SamplePlugin());

	builder.crawlRules().setInputSpec(getInputSpecification());

	CrawljaxRunner crawljax = new CrawljaxRunner(builder.build());
	crawljax.call();
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:26,代碼來源:Runner.java

示例4: testHiddenElementsSiteCrawl

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
/**
 * Shows <a href='https://github.com/crawljax/crawljax/issues/97'>Issue 97</a>
 */
@Test
public void testHiddenElementsSiteCrawl() throws Exception {
	CrawlSession crawl = new BaseCrawler("hidden-elements-site") {
		@Override
		public CrawljaxConfigurationBuilder newCrawlConfigurationBuilder() {
			CrawljaxConfigurationBuilder builder =
			        super.newCrawlConfigurationBuilder();
			builder.crawlRules().crawlHiddenAnchors(true);
			return builder;
		}
	}.crawl();

	StateFlowGraph stateFlowGraph = crawl.getStateFlowGraph();
	/*
	 * TODO Fix issue #97 https://github.com/crawljax/crawljax/issues/97 It is now party hacked
	 * by following HREF links.
	 */
	int withIssue97 = 3 - 1;
	assertThat(stateFlowGraph, hasStates(withIssue97));
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:24,代碼來源:CrawlHiddenElementsTest.java

示例5: chromeProxyConfig

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
@Test
public void chromeProxyConfig() {
	assumeThat(System.getProperty("webdriver.chrome.driver"), is(notNullValue()));
	CrawlSession crawl =
	        new BaseCrawler(Resource.newClassPathResource("/site"),
	                "simplelink/simplelink.html") {
		        @Override
		        public CrawljaxConfigurationBuilder newCrawlConfigurationBuilder() {
			        CrawljaxConfigurationBuilder builder =
			                super.newCrawlConfigurationBuilder();
			        builder.setBrowserConfig(new BrowserConfiguration(BrowserType.CHROME));
			        return builder;
		        }
	        }.crawl();
	assertThat(crawl.getStateFlowGraph(), hasStates(2));
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:17,代碼來源:ChromeProxyConfig.java

示例6: whenStopIsCalledTheCrawlerStopsGracefully

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
@Test(timeout = 60_000)
public void whenStopIsCalledTheCrawlerStopsGracefully() throws Exception {
	CrawljaxConfigurationBuilder builder = SERVER.newConfigBuilder("infinite.html");

	CrawljaxRunner runner = new CrawljaxRunner(builder.setUnlimitedCrawlDepth()
	        .setUnlimitedCrawlDepth()
	        .setUnlimitedStates()
	        .build());

	ExecutorService executor = Executors.newSingleThreadExecutor();
	executor.submit(runner);
	Thread.sleep(TimeUnit.SECONDS.toMillis(15));
	runner.stop();
	executor.shutdown();
	executor.awaitTermination(30, TimeUnit.SECONDS);
	assertThat(runner.getReason(), is(ExitStatus.STOPPED));

}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:19,代碼來源:CrawlerStopTest.java

示例7: getCrawljaxConfiguration

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
/**
 * retrieve / build the CrawljaxConfiguration for the given arguments.
 */
protected CrawljaxConfiguration getCrawljaxConfiguration() {

	CrawljaxConfigurationBuilder builder =
	        CrawljaxConfiguration.builderFor(WEB_SERVER.getSiteUrl());
	builder.crawlRules().waitAfterEvent(getTimeOutAfterEvent(), TimeUnit.MILLISECONDS);
	builder.crawlRules()
	        .waitAfterReloadUrl(getTimeOutAfterReloadUrl(), TimeUnit.MILLISECONDS);
	builder.setMaximumDepth(3);
	builder.crawlRules().clickOnce(true);

	builder.setBrowserConfig(getBrowserConfiguration());

	addCrawlElements(builder);

	builder.crawlRules().setInputSpec(getInputSpecification());

	addCrawlConditions(builder);
	addOracleComparators(builder);
	addInvariants(builder);
	addWaitConditions(builder);
	addPlugins(builder);

	return builder.build();
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:28,代碼來源:LargeTestBase.java

示例8: addPlugins

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
/**
 * Add the plugins to the given crawljaxConfiguration.
 * 
 * @param crawljaxConfiguration
 *            the configuration to add the plugins to.
 */
protected static void addPlugins(CrawljaxConfigurationBuilder crawljaxConfiguration) {
	crawljaxConfiguration.addPlugin(new PostCrawlStateGraphChecker());

	crawljaxConfiguration.addPlugin(new OnInvariantViolationPlugin() {

		@Override
		public void onInvariantViolation(Invariant invariant, CrawlerContext context) {
			LargeTestBase.violatedInvariants.add(invariant);
			if (context.getBrowser().getStrippedDom().contains(INVARIANT_TEXT)) {
				violatedInvariantStateIsCorrect = true;
				LOG.warn("Invariant violated: " + invariant.getDescription());
			}
		}

	});
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:23,代碼來源:LargeTestBase.java

示例9: testExtract

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
@Test
public void testExtract() throws InterruptedException, CrawljaxException {
	CrawljaxConfigurationBuilder builder =
	        CrawljaxConfiguration.builderFor(DEMO_SITE_SERVER.getSiteUrl().toExternalForm());
	builder.crawlRules().click("a");
	builder.crawlRules().clickOnce(true);
	CrawljaxConfiguration config = builder.build();

	CandidateElementExtractor extractor = newElementExtractor(config);
	browser.goToUrl(DEMO_SITE_SERVER.getSiteUrl());
	List<CandidateElement> candidates = extractor.extract(DUMMY_STATE);

	assertNotNull(candidates);
	assertEquals(15, candidates.size());

}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:17,代碼來源:CandidateElementExtractorTest.java

示例10: testExtractExclude

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
@Test
public void testExtractExclude() throws Exception {
	CrawljaxConfigurationBuilder builder =
	        CrawljaxConfiguration.builderFor(DEMO_SITE_SERVER.getSiteUrl().toExternalForm());
	builder.crawlRules().click("a");
	builder.crawlRules().dontClick("div").withAttribute("id", "menubar");
	builder.crawlRules().clickOnce(true);
	CrawljaxConfiguration config = builder.build();

	CandidateElementExtractor extractor = newElementExtractor(config);
	browser.goToUrl(DEMO_SITE_SERVER.getSiteUrl());

	List<CandidateElement> candidates = extractor.extract(DUMMY_STATE);

	assertNotNull(candidates);
	assertThat(candidates, hasSize(11));

}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:19,代碼來源:CandidateElementExtractorTest.java

示例11: testExtractIframeContents

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
@Test
public void testExtractIframeContents() throws Exception {
	RunWithWebServer server = new RunWithWebServer("/site");
	server.before();
	CrawljaxConfigurationBuilder builder =
	        CrawljaxConfiguration
	                .builderFor(server.getSiteUrl().toExternalForm() + "iframe/");
	builder.crawlRules().click("a");
	CrawljaxConfiguration config = builder.build();

	CandidateElementExtractor extractor = newElementExtractor(config);
	browser.goToUrl(new URL(server.getSiteUrl().toExternalForm() + "iframe/"));
	List<CandidateElement> candidates = extractor.extract(DUMMY_STATE);

	for (CandidateElement e : candidates) {
		LOG.debug("candidate: " + e.getUniqueString());
	}

	server.after();

	assertNotNull(extractor);
	assertNotNull(candidates);
	assertThat(candidates, hasSize(9));

}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:26,代碼來源:CandidateElementExtractorTest.java

示例12: get

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
@Override
public OutPutModel get() {
 LoggerFactory.getLogger(RunHoverCrawl.class).info(
         "Running the hover crawl");
 Resource hoverSiteBase =
         Resource.newClassPathResource("hover-test-site");
 BaseCrawler hoverSiteCrawl = new BaseCrawler(hoverSiteBase, "") {
  @Override
  protected CrawljaxConfigurationBuilder newCrawlConfigurationBuilder() {
   CrawljaxConfigurationBuilder builder =
           super.newCrawlConfigurationBuilder().setOutputDirectory(
                   getTempDir());

   return builder;
  };
 };
 CrawlOverview plugin = new CrawlOverview();
 hoverSiteCrawl.crawlWith(plugin);
 return plugin.getResult();
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:21,代碼來源:RunHoverCrawl.java

示例13: runCrawl

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
@BeforeClass
public static void runCrawl() throws Exception {
	outFolder = TMP_FOLDER.getTempDir();
	SimpleSiteCrawl simpleCrawl = new SimpleSiteCrawl() {
		@Override
		protected CrawljaxConfigurationBuilder newCrawlConfigurationBuilder() {
			return super.newCrawlConfigurationBuilder().setOutputDirectory(
			        TMP_FOLDER.getTempDir());
		}
	};
	simpleCrawl.setup();
	CrawlOverview plugin = new CrawlOverview();
	simpleCrawl.crawlWith(plugin);
	result = plugin.getResult();
	LOG.debug("TMP folder is in {}", outFolder.getAbsoluteFile());
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:17,代碼來源:SimpleSiteCrawlTest.java

示例14: newCrawlConfigurationBuilder

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
@Override
protected CrawljaxConfigurationBuilder newCrawlConfigurationBuilder() {
	CrawljaxConfigurationBuilder builder = super.newCrawlConfigurationBuilder();
	builder.crawlRules().click("a").underXPath("//A[@class='click']");
	builder.crawlRules().dontClickChildrenOf("div").withId("dontClick");
	return builder;
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:8,代碼來源:SimpleXpathCrawl.java

示例15: configureTimers

import com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder; //導入依賴的package包/類
private void configureTimers(CrawljaxConfigurationBuilder builder) {
	if (options.specifiesTimeOut()) {
		builder.setMaximumRunTime(options.getSpecifiedTimeOut(), TimeUnit.MINUTES);
	}
	if (options.specifiesWaitAfterEvent()) {
		builder.crawlRules().waitAfterEvent(options.getSpecifiedWaitAfterEvent(),
		        TimeUnit.MILLISECONDS);
	}
	if (options.specifiesWaitAfterReload()) {
		builder.crawlRules().waitAfterReloadUrl(options.getSpecifiedWaitAfterReload(),
		        TimeUnit.MILLISECONDS);
	}
}
 
開發者ID:aminmf,項目名稱:crawljax,代碼行數:14,代碼來源:JarRunner.java


注:本文中的com.crawljax.core.configuration.CrawljaxConfiguration.CrawljaxConfigurationBuilder類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。