Spaces:
Runtime error
Runtime error
import os | |
import sys | |
import pytest | |
import asyncio | |
# Add the parent directory to the Python path | |
parent_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) | |
sys.path.append(parent_dir) | |
from crawl4ai.async_webcrawler import AsyncWebCrawler | |
from crawl4ai.async_crawler_strategy import AsyncPlaywrightCrawlerStrategy | |
async def test_custom_user_agent(): | |
async with AsyncWebCrawler(verbose=True) as crawler: | |
custom_user_agent = "MyCustomUserAgent/1.0" | |
crawler.crawler_strategy.update_user_agent(custom_user_agent) | |
url = "https://httpbin.org/user-agent" | |
result = await crawler.arun(url=url, bypass_cache=True) | |
assert result.success | |
assert custom_user_agent in result.html | |
async def test_custom_headers(): | |
async with AsyncWebCrawler(verbose=True) as crawler: | |
custom_headers = {"X-Test-Header": "TestValue"} | |
crawler.crawler_strategy.set_custom_headers(custom_headers) | |
url = "https://httpbin.org/headers" | |
result = await crawler.arun(url=url, bypass_cache=True) | |
assert result.success | |
assert "X-Test-Header" in result.html | |
assert "TestValue" in result.html | |
async def test_javascript_execution(): | |
async with AsyncWebCrawler(verbose=True) as crawler: | |
js_code = "document.body.innerHTML = '<h1>Modified by JS</h1>';" | |
url = "https://www.example.com" | |
result = await crawler.arun(url=url, bypass_cache=True, js_code=js_code) | |
assert result.success | |
assert "<h1>Modified by JS</h1>" in result.html | |
async def test_hook_execution(): | |
async with AsyncWebCrawler(verbose=True) as crawler: | |
async def test_hook(page): | |
await page.evaluate("document.body.style.backgroundColor = 'red';") | |
return page | |
crawler.crawler_strategy.set_hook('after_goto', test_hook) | |
url = "https://www.example.com" | |
result = await crawler.arun(url=url, bypass_cache=True) | |
assert result.success | |
assert "background-color: red" in result.html | |
async def test_screenshot(): | |
async with AsyncWebCrawler(verbose=True) as crawler: | |
url = "https://www.example.com" | |
result = await crawler.arun(url=url, bypass_cache=True, screenshot=True) | |
assert result.success | |
assert result.screenshot | |
assert isinstance(result.screenshot, str) | |
assert len(result.screenshot) > 0 | |
# Entry point for debugging | |
if __name__ == "__main__": | |
pytest.main([__file__, "-v"]) |