nixpkgs/pkgs/development/python-modules/gradio/default.nix
2024-11-17 15:03:20 +08:00

304 lines
7.1 KiB
Nix

{
lib,
stdenv,
buildPythonPackage,
fetchPypi,
pythonOlder,
writeShellScriptBin,
gradio,
# pyproject
hatchling,
hatch-requirements-txt,
hatch-fancy-pypi-readme,
# runtime
setuptools,
aiofiles,
anyio,
diffusers,
fastapi,
ffmpy,
gradio-client,
httpx,
huggingface-hub,
importlib-resources,
jinja2,
markupsafe,
matplotlib,
numpy,
orjson,
packaging,
pandas,
pillow,
pydantic,
python-multipart,
pydub,
pyyaml,
semantic-version,
typing-extensions,
uvicorn,
typer,
tomlkit,
# oauth
authlib,
itsdangerous,
# check
pytestCheckHook,
hypothesis,
altair,
boto3,
gradio-pdf,
ffmpeg,
ipython,
pytest-asyncio,
respx,
scikit-image,
torch,
tqdm,
transformers,
vega-datasets,
}:
buildPythonPackage rec {
pname = "gradio";
version = "5.1.0";
pyproject = true;
disabled = pythonOlder "3.7";
# We use the Pypi release, since it provides prebuilt webui assets
src = fetchPypi {
inherit pname version;
hash = "sha256-0hU2aObeLfegG7M/AaB0/HcW7IY8QPRy2OQ5Q57x4VM=";
};
# fix packaging.ParserSyntaxError, which can't handle comments
postPatch = ''
sed -ie "s/ #.*$//g" requirements*.txt
# they bundle deps?
rm -rf venv/
'';
pythonRelaxDeps = [
"tomlkit"
"aiofiles"
"markupsafe"
"pillow"
];
pythonRemoveDeps = [
# our package is presented as a binary, not a python lib - and
# this isn't a real runtime dependency
"ruff"
];
build-system = [
hatchling
hatch-requirements-txt
hatch-fancy-pypi-readme
];
dependencies = [
setuptools # needed for 'pkg_resources'
aiofiles
anyio
diffusers
fastapi
ffmpy
gradio-client
httpx
huggingface-hub
importlib-resources
jinja2
markupsafe
matplotlib
numpy
orjson
packaging
pandas
pillow
pydantic
python-multipart
pydub
pyyaml
semantic-version
typing-extensions
uvicorn
typer
tomlkit
];
optional-dependencies.oauth = [
authlib
itsdangerous
];
nativeCheckInputs = [
pytestCheckHook
hypothesis
altair
boto3
gradio-pdf
ffmpeg
ipython
pytest-asyncio
respx
scikit-image
# shap is needed as well, but breaks too often
torch
tqdm
transformers
vega-datasets
# mock calls to `shutil.which(...)`
(writeShellScriptBin "npm" "false")
] ++ optional-dependencies.oauth ++ pydantic.optional-dependencies.email;
# Add a pytest hook skipping tests that access network, marking them as "Expected fail" (xfail).
# We additionally xfail FileNotFoundError, since the gradio devs often fail to upload test assets to pypi.
preCheck =
''
export HOME=$TMPDIR
cat ${./conftest-skip-network-errors.py} >> test/conftest.py
''
+ lib.optionalString stdenv.hostPlatform.isDarwin ''
# OSError: [Errno 24] Too many open files
ulimit -n 4096
'';
disabledTests =
[
# Actually broken
"test_mount_gradio_app"
"test_processing_utils_backwards_compatibility" # type error
# requires network, it caught our xfail exception
"test_error_analytics_successful"
# Flaky, tries to pin dependency behaviour. Sensitive to dep versions
# These error only affect downstream use of the check dependencies.
"test_no_color"
"test_in_interface_as_output"
"test_should_warn_url_not_having_version"
# Flaky, unknown reason
"test_in_interface"
# shap is too often broken in nixpkgs
"test_shapley_text"
# fails without network
"test_download_if_url_correct_parse"
# flaky: OSError: Cannot find empty port in range: 7860-7959
"test_docs_url"
"test_orjson_serialization"
"test_dataset_is_updated"
"test_multimodal_api"
# tests if pip and other tools are installed
"test_get_executable_path"
]
++ lib.optionals stdenv.hostPlatform.isDarwin [
# flaky on darwin (depend on port availability)
"test_all_status_messages"
"test_async_generators"
"test_async_generators_interface"
"test_async_iterator_update_with_new_component"
"test_concurrency_limits"
"test_default_concurrency_limits"
"test_default_flagging_callback"
"test_end_to_end"
"test_end_to_end_cache_examples"
"test_event_data"
"test_every_does_not_block_queue"
"test_example_caching_relaunch"
"test_example_caching_relaunch"
"test_exit_called_at_launch"
"test_file_component_uploads"
"test_files_saved_as_file_paths"
"test_flagging_does_not_create_unnecessary_directories"
"test_flagging_no_permission_error_with_flagging_disabled"
"test_info_and_warning_alerts"
"test_info_isolation"
"test_launch_analytics_does_not_error_with_invalid_blocks"
"test_no_empty_audio_files"
"test_no_empty_image_files"
"test_no_empty_video_files"
"test_non_streaming_api"
"test_non_streaming_api_async"
"test_pil_images_hashed"
"test_progress_bar"
"test_progress_bar_track_tqdm"
"test_queue_when_using_auth"
"test_restart_after_close"
"test_set_share_in_colab"
"test_show_error"
"test_simple_csv_flagging_callback"
"test_single_request"
"test_socket_reuse"
"test_start_server"
"test_state_holder_is_used_in_postprocess"
"test_state_stored_up_to_capacity"
"test_static_files_single_app"
"test_streaming_api"
"test_streaming_api_async"
"test_streaming_api_with_additional_inputs"
"test_sync_generators"
"test_time_to_live_and_delete_callback_for_state"
"test_updates_stored_up_to_capacity"
"test_varying_output_forms_with_generators"
];
disabledTestPaths = [
# 100% touches network
"test/test_networking.py"
# makes pytest freeze 50% of the time
"test/test_interfaces.py"
# Local network tests dependant on port availability (port 7860-7959)
"test/test_routes.py"
];
pytestFlagsArray = [
"-x" # abort on first failure
"-m 'not flaky'"
#"-W" "ignore" # uncomment for debugging help
];
# check the binary works outside the build env
doInstallCheck = true;
postInstallCheck = ''
env --ignore-environment $out/bin/gradio environment >/dev/null
'';
pythonImportsCheck = [ "gradio" ];
# Cyclic dependencies are fun!
# This is gradio without gradio-client and gradio-pdf
passthru.sans-reverse-dependencies =
(gradio.override (old: {
gradio-client = null;
gradio-pdf = null;
})).overridePythonAttrs
(old: {
pname = old.pname + "-sans-reverse-dependencies";
pythonRemoveDeps = (old.pythonRemoveDeps or [ ]) ++ [ "gradio-client" ];
doInstallCheck = false;
doCheck = false;
preCheck = "";
pythonImportsCheck = null;
dontCheckRuntimeDeps = true;
});
meta = {
homepage = "https://www.gradio.app/";
changelog = "https://github.com/gradio-app/gradio/releases/tag/gradio@${version}";
description = "Python library for easily interacting with trained machine learning models";
license = lib.licenses.asl20;
maintainers = with lib.maintainers; [ pbsds ];
};
}