about summary refs log tree commit diff
path: root/pkgs/development/python-modules/confluent-kafka
diff options
context:
space:
mode:
authorFabian Affolter <mail@fabian-affolter.ch>2023-06-24 23:16:03 +0200
committerFabian Affolter <mail@fabian-affolter.ch>2023-06-24 23:16:03 +0200
commit12ef4ebea7c13c668981e526297b3b6ca58ff068 (patch)
tree9554b643b4144cc216a2c2e4e15fdcd1e76b7ff7 /pkgs/development/python-modules/confluent-kafka
parent2dee09084f74732ab328b1ad4dbd29498bd4ac27 (diff)
python310Packages.confluent-kafka: add optional-dependencies
- enable tests
- add pythonImportsCheck
- add format
- disable on unsupported Python releases
Diffstat (limited to 'pkgs/development/python-modules/confluent-kafka')
-rw-r--r--pkgs/development/python-modules/confluent-kafka/default.nix66
1 files changed, 58 insertions, 8 deletions
diff --git a/pkgs/development/python-modules/confluent-kafka/default.nix b/pkgs/development/python-modules/confluent-kafka/default.nix
index 0a0433741bd56..03cdb826786ce 100644
--- a/pkgs/development/python-modules/confluent-kafka/default.nix
+++ b/pkgs/development/python-modules/confluent-kafka/default.nix
@@ -1,18 +1,68 @@
-{ lib, buildPythonPackage, fetchPypi, isPy3k, rdkafka, requests, avro3k, avro ? null, futures ? null, enum34 ? null }:
+{ lib
+, avro
+, buildPythonPackage
+, fastavro
+, fetchFromGitHub
+, jsonschema
+, protobuf
+, pyflakes
+, pyrsistent
+, pytestCheckHook
+, pythonOlder
+, rdkafka
+, requests
+, requests-mock
+}:
 
 buildPythonPackage rec {
-  version = "2.1.1";
   pname = "confluent-kafka";
+  version = "2.1.1";
+  format = "setuptools";
+
+  disabled = pythonOlder "3.7";
+
+  src = fetchFromGitHub {
+    owner = "confluentinc";
+    repo = "confluent-kafka-python";
+    rev = "refs/tags/v${version}";
+    hash = "sha256-xnbovQRvbhaYYXnssV0Jy+U9L6BUddIagbup2jdTugY=";
+  };
+
+  buildInputs = [
+    rdkafka
+  ];
 
-  src = fetchPypi {
-    inherit pname version;
-    hash = "sha256-pmXnQDCoXF9CA1OM/nfkARM6hJxLkgUqYCJbJgUqfp0=";
+  propagatedBuildInputs = [
+    requests
+  ];
+
+  passthru.optional-dependencies = {
+    avro = [
+      avro
+      fastavro
+    ];
+    json = [
+      jsonschema
+      pyrsistent
+    ];
+    protobuf = [
+      protobuf
+    ];
   };
 
-  buildInputs = [ rdkafka requests ] ++ (if isPy3k then [ avro3k ] else [ enum34 avro futures ]) ;
+  nativeCheckInputs = [
+    pyflakes
+    pytestCheckHook
+    requests-mock
+  ] ++ lib.flatten (builtins.attrValues passthru.optional-dependencies);
+
+  pythonImportsCheck = [
+    "confluent_kafka"
+  ];
 
-  # No tests in PyPi Tarball
-  doCheck = false;
+  disabledTestPaths = [
+    "tests/integration/"
+  ];
 
   meta = with lib; {
     description = "Confluent's Apache Kafka client for Python";