depot/third_party/nixpkgs/pkgs/development/julia-modules/tests
Default email fa5436e0a7 Project import generated by Copybara.
GitOrigin-RevId: e8057b67ebf307f01bdcc8fba94d94f75039d1f6
2024-06-05 17:53:02 +02:00
..
julia-top-n Project import generated by Copybara. 2024-06-05 17:53:02 +02:00
.gitignore Project import generated by Copybara. 2024-01-13 09:15:51 +01:00
process_top_n.py Project import generated by Copybara. 2024-01-13 09:15:51 +01:00
README.md Project import generated by Copybara. 2024-01-13 09:15:51 +01:00
run_tests.sh Project import generated by Copybara. 2024-01-13 09:15:51 +01:00
top-julia-packages.nix Project import generated by Copybara. 2024-01-13 09:15:51 +01:00

Testing julia.withPackages

This folder contains a test suite for ensuring that the top N most popular Julia packages (as measured by download count) work properly. The key parts are

  • top-julia-packages.nix: an impure derivation for fetching Julia download data and processing it into a file called top-julia-packages.yaml. This YAML file contains an array of objects with fields "name", "uuid", and "count", and is sorted in decreasing order of count.
  • julia-top-n: a small Haskell program which reads top-julia-packages.yaml and builds a julia.withPackages environment for each package, with a nice interactive display and configurable parallelism. It also tests whether evaluating using <package-name> works in the resulting environment.

Warning: These tests should only be run on maintainer machines, not Hydra! julia.withPackages uses IFD, which is not allowed in Hydra.

Quick start

# Test the top 100 Julia packages
./run_tests.sh -n 100

Options

You can run ./run_tests.sh --help to see additional options for the test harness. The main ones are

  • -n/--top-n: how many of the top packages to build (default: 100).
  • -p/--parallelism: how many builds to run at once (default: 10).
  • -c/--count-file: path to top-julia-packages.yaml.