mirror of
https://github.com/browser-use/browser-use
synced 2026-05-06 17:52:15 +02:00
* Validator * Test mind2web * Cleaned up logger * Pytest logger * Cleaned up logger * Disable flag for human input * Multiple clicks per button * Multiple clicks per button * More structured system prompt * Fields with description * System prompt example * One logger * Cleaner logging * Log step in step function * Fix critical clicking error - wrong argument used * Improved thought process of agent * Improve system prompt * Remove human input message * Custome action registration * Pydantic model for custom actions * Pydantic model for custome output * Runs through, model outputs functions, but not called yet * Work in progress - description for custome actions * Description works, but schema not yet * Model can call the right action - but is not executed * Seperate is_controller_action and is_custom_action * Works! Model can call custom function * Use registry for action, but result is not feed back to model * Include result in messages * Works with custom function - but typing is not correct * Renamed registry * First test cases * Captcha tests * Pydantic for tests * Improve prompts for multy step * System prompt structure * Handle errors like validation error * Refactor error handling in agent * Refactor error handling in agent * Improved logging * Update view * Fix click parameter to index * Simplify dynamic actions * Use run instead of step * Rename history * Rename AgentService to Agent * Rename ControllerService to Controller * Pytest file * Rename get state * Rename BrowserService * reversed dom extraction recursion to while * Rename use_vision * Rename use_vision * reversed dom tree items and made browser less anoying * Renaming and fixing type errors * Renamed class names for agent * updated requirements * Update prompt * Action registration works for user and controller * Fix done call by returning ActionResult * Fix if result is none * Rename AgentOutput and ActionModel * Improved prompt Passes 6/8 tests from test_agent_actions * Calculate token cost * Improve display * Simplified logger * Test function calling * created super simple xpath extraction algo * Tests logging * tiny fixes to dom extraction * Remove test * Dont log number of clicks * Pytest file * merged per element js checks * Check if driver is still open * super fast processing * fixed agent planning and stuff * Fix example * Fix example * Improve error * Improved error correction * New line for step * small type error fixes * Test for pydantic * Fix line * Removed sample * fixed readme and examples --------- Co-authored-by: magmueller <mamagnus00@gmail.com>
51 lines
1.2 KiB
Python
51 lines
1.2 KiB
Python
import time
|
|
|
|
import pytest
|
|
from selenium import webdriver
|
|
from selenium.webdriver.chrome.options import Options
|
|
from selenium.webdriver.chrome.service import Service
|
|
from webdriver_manager.chrome import ChromeDriverManager
|
|
|
|
|
|
def test_selenium():
|
|
try:
|
|
print('1. Setting up Chrome options...')
|
|
chrome_options = Options()
|
|
chrome_options.add_argument('--no-sandbox')
|
|
# Uncomment to test headless mode
|
|
# chrome_options.add_argument('--headless=new')
|
|
|
|
print('2. Installing/finding ChromeDriver...')
|
|
service = Service(ChromeDriverManager().install())
|
|
|
|
print('3. Creating Chrome WebDriver...')
|
|
driver = webdriver.Chrome(service=service, options=chrome_options)
|
|
|
|
print('4. Navigating to Google...')
|
|
driver.get('https://www.google.com')
|
|
|
|
print('5. Getting page title...')
|
|
title = driver.title
|
|
print(f'Page title: {title}')
|
|
|
|
time.sleep(2) # Wait to see the page if not in headless mode
|
|
|
|
print('6. Closing browser...')
|
|
driver.quit()
|
|
|
|
print('✅ Test completed successfully!')
|
|
return True
|
|
|
|
except Exception as e:
|
|
print(f'❌ Test failed with error: {str(e)}')
|
|
print(f'Error type: {type(e).__name__}')
|
|
return False
|
|
|
|
|
|
# run with: pytest browser_use/browser/tests/test_selenium.py
|
|
|
|
#
|
|
|
|
if __name__ == '__main__':
|
|
pytest.main([__file__, '-v'])
|