depot/third_party/nixpkgs/pkgs/development/python-modules/datasette/default.nix
Default email bcb2f287e1 Project import generated by Copybara.
GitOrigin-RevId: d603719ec6e294f034936c0d0dc06f689d91b6c3
2024-06-20 20:27:18 +05:30

107 lines
2 KiB
Nix

{
lib,
buildPythonPackage,
fetchFromGitHub,
aiofiles,
asgi-csrf,
click,
click-default-group,
itsdangerous,
janus,
jinja2,
hupper,
mergedeep,
pint,
pluggy,
python-baseconv,
pyyaml,
uvicorn,
httpx,
pytestCheckHook,
pytest-asyncio,
pytest-timeout,
aiohttp,
beautifulsoup4,
asgiref,
setuptools,
trustme,
pythonOlder,
}:
buildPythonPackage rec {
pname = "datasette";
version = "0.64.7";
format = "setuptools";
disabled = pythonOlder "3.8";
src = fetchFromGitHub {
owner = "simonw";
repo = pname;
rev = "refs/tags/${version}";
hash = "sha256-MxTCVgV0xDKXiYOx6rh5v55uQqlf9Wd06wHfnhDS4Hk=";
};
postPatch = ''
substituteInPlace setup.py \
--replace '"pytest-runner"' ""
'';
propagatedBuildInputs = [
aiofiles
asgi-csrf
asgiref
click
click-default-group
httpx
hupper
itsdangerous
janus
jinja2
mergedeep
pint
pluggy
python-baseconv
pyyaml
setuptools
uvicorn
];
nativeCheckInputs = [
aiohttp
beautifulsoup4
pytest-asyncio
pytest-timeout
pytestCheckHook
trustme
];
# takes 30-180 mins to run entire test suite, not worth the CPU resources, slows down reviews
# with pytest-xdist, it still takes around 10 mins with 32 cores
# just run the csv tests, as this should give some indictation of correctness
pytestFlagsArray = [ "tests/test_csv.py" ];
disabledTests = [
"facet"
"_invalid_database" # checks error message when connecting to invalid database
];
pythonImportsCheck = [
"datasette"
"datasette.cli"
"datasette.app"
"datasette.database"
"datasette.renderer"
"datasette.tracer"
"datasette.plugins"
];
meta = with lib; {
description = "Multi-tool for exploring and publishing data";
mainProgram = "datasette";
homepage = "https://datasette.io/";
changelog = "https://github.com/simonw/datasette/releases/tag/${version}";
license = licenses.asl20;
maintainers = with maintainers; [ ];
};
}