mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-24 10:54:04 +08:00
3b9494f5c5
* Fix the analytics module to use asyncio to work in the Wasm env
* add changeset
* add changeset
* Add changeset
* Revert "Add changeset"
This reverts commit 052f2bd737
.
* Add the `is_wasm` field to the analytics telemetry
* Restore the initialization code in Blocks.launch() in the Wasm env
* Remove a call of analytics.version_check() in Blocks.launch() in the Wasm mode
* Add a `type: ignore` directive to the line of importing the `pyodide` module
* Fix a test case
* Refactor _do_wasm_analytics_request() and add a unit test for it
* Get the IP address for analytics in the Wasm mode
---------
Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com>
Co-authored-by: Abubakar Abid <abubakar@huggingface.co>
88 lines
2.9 KiB
Python
88 lines
2.9 KiB
Python
import asyncio
|
|
import ipaddress
|
|
import json
|
|
import os
|
|
import warnings
|
|
from unittest import mock as mock
|
|
|
|
import pytest
|
|
import requests
|
|
|
|
from gradio import analytics, wasm_utils
|
|
from gradio.context import Context
|
|
|
|
os.environ["GRADIO_ANALYTICS_ENABLED"] = "False"
|
|
|
|
|
|
class TestAnalytics:
|
|
@mock.patch("requests.get")
|
|
def test_should_warn_with_unable_to_parse(self, mock_get, monkeypatch):
|
|
monkeypatch.setenv("GRADIO_ANALYTICS_ENABLED", "True")
|
|
mock_get.side_effect = json.decoder.JSONDecodeError("Expecting value", "", 0)
|
|
|
|
with warnings.catch_warnings(record=True) as w:
|
|
warnings.simplefilter("always")
|
|
analytics.version_check()
|
|
assert (
|
|
str(w[-1].message)
|
|
== "unable to parse version details from package URL."
|
|
)
|
|
|
|
@mock.patch("requests.post")
|
|
def test_error_analytics_doesnt_crash_on_connection_error(
|
|
self, mock_post, monkeypatch
|
|
):
|
|
monkeypatch.setenv("GRADIO_ANALYTICS_ENABLED", "True")
|
|
mock_post.side_effect = requests.ConnectionError()
|
|
analytics._do_normal_analytics_request("placeholder", {})
|
|
mock_post.assert_called()
|
|
|
|
@mock.patch("requests.post")
|
|
def test_error_analytics_successful(self, mock_post, monkeypatch):
|
|
monkeypatch.setenv("GRADIO_ANALYTICS_ENABLED", "True")
|
|
analytics.error_analytics("placeholder")
|
|
mock_post.assert_called()
|
|
|
|
@mock.patch.object(wasm_utils, "IS_WASM", True)
|
|
@mock.patch("gradio.analytics.pyodide_pyfetch")
|
|
@pytest.mark.asyncio
|
|
async def test_error_analytics_successful_in_wasm_mode(
|
|
self, pyodide_pyfetch, monkeypatch
|
|
):
|
|
loop = asyncio.get_event_loop()
|
|
monkeypatch.setenv("GRADIO_ANALYTICS_ENABLED", "True")
|
|
|
|
analytics.error_analytics("placeholder")
|
|
|
|
# Await all background tasks.
|
|
# Ref: https://superfastpython.com/asyncio-wait-for-tasks/#How_to_Wait_for_All_Background_Tasks
|
|
all_tasks = asyncio.all_tasks(loop)
|
|
current_task = asyncio.current_task()
|
|
all_tasks.remove(current_task)
|
|
await asyncio.wait(all_tasks)
|
|
|
|
pyodide_pyfetch.assert_called()
|
|
|
|
|
|
class TestIPAddress:
|
|
@pytest.mark.flaky
|
|
def test_get_ip(self):
|
|
Context.ip_address = None
|
|
ip = analytics.get_local_ip_address()
|
|
if ip == "No internet connection" or ip == "Analytics disabled":
|
|
return
|
|
ipaddress.ip_address(ip)
|
|
|
|
@mock.patch("requests.get")
|
|
def test_get_ip_without_internet(self, mock_get, monkeypatch):
|
|
mock_get.side_effect = requests.ConnectionError()
|
|
monkeypatch.setenv("GRADIO_ANALYTICS_ENABLED", "True")
|
|
Context.ip_address = None
|
|
ip = analytics.get_local_ip_address()
|
|
assert ip == "No internet connection"
|
|
|
|
monkeypatch.setenv("GRADIO_ANALYTICS_ENABLED", "False")
|
|
Context.ip_address = None
|
|
ip = analytics.get_local_ip_address()
|
|
assert ip == "Analytics disabled"
|