mirror of
https://github.com/microsoft/autogen.git
synced 2025-07-31 04:42:09 +00:00

* Feat/headless browser (retargeted) (#1832) * Add headless browser to the WebSurferAgent, closes #1481 * replace soup.get_text() with markdownify.MarkdownConverter().convert_soup(soup) * import HeadlessChromeBrowser * implicitly wait for 10s * inicrease max. wait time to 99s * fix: trim trailing whitespace * test: fix headless tests * better bing query search * docs: add example 3 for headless option --------- Co-authored-by: Vijay Ramesh <vijay@regrello.com> * Handle missing Selenium package. * Added browser_chat.py example to simplify testing. * Based browser on mdconvert. (#1847) * Based browser on mdconvert. * Updated web_surfer. * Renamed HeadlessChromeBrowser to SeleniumChromeBrowser * Added an initial POC with Playwright. * Separated Bing search into it's own utility module. * Simple browser now uses Bing tools. * Updated Playwright browser to inherit from SimpleTextBrowser * Got Selenium working too. * Renamed classes and files for consistency. * Added more instructions. * Initial work to support other search providers. * Added some basic behavior when the BING_API_KEY is missing. * Cleaned up some search results. * Moved to using the request.Sessions object. Moved Bing SERP paring to mdconvert to be more broadly useful. * Added backward compatibility to WebSurferAgent * Selenium and Playwright now grab the whole DOM, not jus the body, allowing the converters access to metadata. * Fixed printing of page titles in Playwright. * Moved installation of WebSurfer dependencies to contrib-tests.yml * Fixing pre-commit issues. * Reverting conversable_agent, which should not have been changed in prior commit. * Added RequestMarkdownBrowser tests. * Fixed a bug with Bing search, and added search test cases. * Added tests for Bing search. * Added tests for md_convert * Added test files. * Added missing pptx. * Added more tests for WebSurfer coverage. * Fixed guard on requests_markdown_browser test. * Updated test coverage for mdconvert. * Fix brwser_utils tests. * Removed image test from browser, since exiftool isn't installed on test machine. * Removed image test from browser, since exiftool isn't installed on test machine. * Disable Selenium GPU and sandbox to ensure it runs headless in Docker. * Added option for Bing API results to be interleaved (as Bing specifies), or presented in a categorized list (Web, News, Videos), etc * Print more details when requests exceptions are thrown. * Added additional documentation to markdown_search * Added documentation to the selenium_markdown_browser. * Added documentation to playwright_markdown_browser.py * Added documentation to requests_markdown_browser * Added documentation to mdconvert.py * Updated agentchat_surfer notebook. * Update .github/workflows/contrib-tests.yml Co-authored-by: Davor Runje <davor@airt.ai> * Merge main. Resolve conflicts. * Resolve pre-commit checks. * Removed offending LFS file. * Re-added offending LFS file. * Fixed browser_utils tests. * Fixed style errors. --------- Co-authored-by: Asapanna Rakesh <45640029+INF800@users.noreply.github.com> Co-authored-by: Vijay Ramesh <vijay@regrello.com> Co-authored-by: Eric Zhu <ekzhu@users.noreply.github.com> Co-authored-by: Davor Runje <davor@airt.ai>
176 lines
6.2 KiB
Python
176 lines
6.2 KiB
Python
#!/usr/bin/env python3 -m pytest
|
||
import io
|
||
import os
|
||
import shutil
|
||
|
||
import pytest
|
||
import requests
|
||
|
||
try:
|
||
from autogen.browser_utils import FileConversionException, MarkdownConverter, UnsupportedFormatException
|
||
except ImportError:
|
||
skip_all = True
|
||
else:
|
||
skip_all = False
|
||
|
||
skip_exiftool = shutil.which("exiftool") is None
|
||
|
||
TEST_FILES_DIR = os.path.join(os.path.dirname(__file__), "test_files")
|
||
|
||
JPG_TEST_EXIFTOOL = {
|
||
"Author": "AutoGen Authors",
|
||
"Title": "AutoGen: Enabling Next-Gen LLM Applications via Multi-Agent Conversation",
|
||
"Description": "AutoGen enables diverse LLM-based applications",
|
||
"ImageSize": "1615x1967",
|
||
"DateTimeOriginal": "2024:03:14 22:10:00",
|
||
}
|
||
|
||
PDF_TEST_URL = "https://arxiv.org/pdf/2308.08155v2.pdf"
|
||
PDF_TEST_STRINGS = ["While there is contemporaneous exploration of multi-agent approaches"]
|
||
|
||
YOUTUBE_TEST_URL = "https://www.youtube.com/watch?v=V2qZ_lgxTzg"
|
||
YOUTUBE_TEST_STRINGS = [
|
||
"## AutoGen FULL Tutorial with Python (Step-By-Step)",
|
||
"This is an intermediate tutorial for installing and using AutoGen locally",
|
||
"PT15M4S",
|
||
"the model we're going to be using today is GPT 3.5 turbo", # From the transcript
|
||
]
|
||
|
||
XLSX_TEST_STRINGS = [
|
||
"## 09060124-b5e7-4717-9d07-3c046eb",
|
||
"6ff4173b-42a5-4784-9b19-f49caff4d93d",
|
||
"affc7dad-52dc-4b98-9b5d-51e65d8a8ad0",
|
||
]
|
||
|
||
DOCX_TEST_STRINGS = [
|
||
"314b0a30-5b04-470b-b9f7-eed2c2bec74a",
|
||
"49e168b7-d2ae-407f-a055-2167576f39a1",
|
||
"## d666f1f7-46cb-42bd-9a39-9a39cf2a509f",
|
||
"# Abstract",
|
||
"# Introduction",
|
||
"AutoGen: Enabling Next-Gen LLM Applications via Multi-Agent Conversation",
|
||
]
|
||
|
||
PPTX_TEST_STRINGS = [
|
||
"2cdda5c8-e50e-4db4-b5f0-9722a649f455",
|
||
"04191ea8-5c73-4215-a1d3-1cfb43aaaf12",
|
||
"44bf7d06-5e7a-4a40-a2e1-a2e42ef28c8a",
|
||
"1b92870d-e3b5-4e65-8153-919f4ff45592",
|
||
"AutoGen: Enabling Next-Gen LLM Applications via Multi-Agent Conversation",
|
||
]
|
||
|
||
BLOG_TEST_URL = "https://microsoft.github.io/autogen/blog/2023/04/21/LLM-tuning-math"
|
||
BLOG_TEST_STRINGS = [
|
||
"Large language models (LLMs) are powerful tools that can generate natural language texts for various applications, such as chatbots, summarization, translation, and more. GPT-4 is currently the state of the art LLM in the world. Is model selection irrelevant? What about inference parameters?",
|
||
"an example where high cost can easily prevent a generic complex",
|
||
]
|
||
|
||
WIKIPEDIA_TEST_URL = "https://en.wikipedia.org/wiki/Microsoft"
|
||
WIKIPEDIA_TEST_STRINGS = [
|
||
"Microsoft entered the operating system (OS) business in 1980 with its own version of [Unix]",
|
||
'Microsoft was founded by [Bill Gates](/wiki/Bill_Gates "Bill Gates")',
|
||
]
|
||
WIKIPEDIA_TEST_EXCLUDES = [
|
||
"You are encouraged to create an account and log in",
|
||
"154 languages",
|
||
"move to sidebar",
|
||
]
|
||
|
||
SERP_TEST_URL = "https://www.bing.com/search?q=microsoft+wikipedia"
|
||
SERP_TEST_STRINGS = [
|
||
"](https://en.wikipedia.org/wiki/Microsoft",
|
||
"Microsoft Corporation is **an American multinational corporation and technology company headquartered** in Redmond",
|
||
"1995–2007: Foray into the Web, Windows 95, Windows XP, and Xbox",
|
||
]
|
||
SERP_TEST_EXCLUDES = [
|
||
"https://www.bing.com/ck/a?!&&p=",
|
||
"data:image/svg+xml,%3Csvg%20width%3D",
|
||
]
|
||
|
||
|
||
@pytest.mark.skipif(
|
||
skip_all,
|
||
reason="do not run if dependency is not installed",
|
||
)
|
||
def test_mdconvert_remote():
|
||
mdconvert = MarkdownConverter()
|
||
|
||
# By URL
|
||
result = mdconvert.convert(PDF_TEST_URL)
|
||
for test_string in PDF_TEST_STRINGS:
|
||
assert test_string in result.text_content
|
||
|
||
# By stream
|
||
response = requests.get(PDF_TEST_URL)
|
||
result = mdconvert.convert_stream(io.BytesIO(response.content), file_extension=".pdf", url=PDF_TEST_URL)
|
||
for test_string in PDF_TEST_STRINGS:
|
||
assert test_string in result.text_content
|
||
|
||
# # Youtube
|
||
# result = mdconvert.convert(YOUTUBE_TEST_URL)
|
||
# for test_string in YOUTUBE_TEST_STRINGS:
|
||
# assert test_string in result.text_content
|
||
|
||
|
||
@pytest.mark.skipif(
|
||
skip_all,
|
||
reason="do not run if dependency is not installed",
|
||
)
|
||
def test_mdconvert_local():
|
||
mdconvert = MarkdownConverter()
|
||
|
||
# Test XLSX processing
|
||
result = mdconvert.convert(os.path.join(TEST_FILES_DIR, "test.xlsx"))
|
||
for test_string in XLSX_TEST_STRINGS:
|
||
assert test_string in result.text_content.replace(r"\-", "-")
|
||
|
||
# Test DOCX processing
|
||
result = mdconvert.convert(os.path.join(TEST_FILES_DIR, "test.docx"))
|
||
for test_string in DOCX_TEST_STRINGS:
|
||
assert test_string in result.text_content.replace(r"\-", "-")
|
||
|
||
# Test PPTX processing
|
||
result = mdconvert.convert(os.path.join(TEST_FILES_DIR, "test.pptx"))
|
||
for test_string in PPTX_TEST_STRINGS:
|
||
assert test_string in result.text_content.replace(r"\-", "-")
|
||
|
||
# Test HTML processing
|
||
result = mdconvert.convert(os.path.join(TEST_FILES_DIR, "test_blog.html"), url=BLOG_TEST_URL)
|
||
for test_string in BLOG_TEST_STRINGS:
|
||
assert test_string in result.text_content.replace(r"\-", "-")
|
||
|
||
# Test Wikipedia processing
|
||
result = mdconvert.convert(os.path.join(TEST_FILES_DIR, "test_wikipedia.html"), url=WIKIPEDIA_TEST_URL)
|
||
for test_string in WIKIPEDIA_TEST_EXCLUDES:
|
||
assert test_string not in result.text_content.replace(r"\-", "-")
|
||
for test_string in WIKIPEDIA_TEST_STRINGS:
|
||
assert test_string in result.text_content.replace(r"\-", "-")
|
||
|
||
# Test Bing processing
|
||
result = mdconvert.convert(os.path.join(TEST_FILES_DIR, "test_serp.html"), url=SERP_TEST_URL)
|
||
for test_string in SERP_TEST_EXCLUDES:
|
||
assert test_string not in result.text_content.replace(r"\-", "-")
|
||
for test_string in SERP_TEST_STRINGS:
|
||
assert test_string in result.text_content.replace(r"\-", "-")
|
||
|
||
|
||
@pytest.mark.skipif(
|
||
skip_exiftool,
|
||
reason="do not run if exiftool is not installed",
|
||
)
|
||
def test_mdconvert_exiftool():
|
||
mdconvert = MarkdownConverter()
|
||
|
||
# Test JPG metadata processing
|
||
result = mdconvert.convert(os.path.join(TEST_FILES_DIR, "test.jpg"))
|
||
for key in JPG_TEST_EXIFTOOL:
|
||
target = f"{key}: {JPG_TEST_EXIFTOOL[key]}"
|
||
assert target in result.text_content
|
||
|
||
|
||
if __name__ == "__main__":
|
||
"""Runs this file's tests from the command line."""
|
||
test_mdconvert_remote()
|
||
test_mdconvert_local()
|
||
test_mdconvert_exiftool()
|