1
0
mirror of https://github.com/pyenv/pyenv.git synced 2025-11-08 11:33:49 -05:00
Files
pyenv/test
rockandska 22a7c46d54 upgrade pip detetcion in pip-rehash to accept multiple variations: (#3330)
- pip
- pipX
- pipX.Y
- * -m pip

Co-authored-by: Christian Fredrik Johnsen <christian@johnsen.no>
2025-09-17 03:53:37 +03:00
..
2025-09-15 20:16:11 +02:00
2025-09-15 16:45:02 +02:00
2025-09-15 20:16:31 +02:00
2018-04-24 00:42:47 +00:00
2025-09-15 20:16:18 +02:00
2021-02-23 22:29:56 +02:00
2025-09-15 16:45:02 +02:00

TEST


Running test suite

Test suite could be launch with make by providing the right target depending what you want to achieve.

Under the hood, pyenv test suites use bats as a test framework and are run on the host or docker depending of the target provided to make.

Targets

  • test
    • Run the whole test suite on the local host
  • test-docker
    • Run the whole test suite on docker
      • Some volumes are used in read-only mode
  • test-unit
    • Run the unit test
  • test-plugin
    • Run the plugin test
  • test-unit-docker-[BASH_VERSION]
    • Run the unit test under official bash docker container (alpine/busybox) with the specified bash version if present is in the Makefile
    • Some volumes are used in read-only mode
  • test-unit-docker-gnu-[BASH_VERSION]
    • Run the unit test under official bash docker container (alpine/busybox), completed by GNU Tools, with the specified bash version if present is in the Makefile
    • Some volumes are used in read-only mode
  • test-plugin-docker-[BASH_VERSION]
    • Run the plugin test under official bash docker container (alpine/busybox), completed by GNU Tools, with the specified bash version if present is in the Makefile
    • Some volumes are used in read-only mode
  • test-plugin-docker-gnu-[BASH_VERSION]
    • Run the plugin test under official bash docker container (alpine/busybox), completed by GNU Tools, with the specified bash version if present is in the Makefile
    • Some volumes are used in read-only mode

Targeting specific test / test file

By setting some environment variables, it is possible to filtering which test and/or test file who will be tested with bats

  • BATS_FILE_FILTER

    • Run test only with the specified file
  • BATS_TEST_FILTER

    • Run test only who corresponding to the filter provided

Examples

    $ BATS_TEST_FILTER=".*installed.*" BATS_FILE_FILTER="build.bats" make test-plugin-docker-gnu-3.2.57
    build.bats
     ✓ yaml is installed for python
     ✓ homebrew is used in Linux if Pyenv is installed with Homebrew
     ✓ homebrew is not used in Linux if Pyenv is not installed with Homebrew
    
    3 tests, 0 failures
    
    $ BATS_TEST_FILTER=".*installed.*" BATS_FILE_FILTER="build.bats" make test-plugin
    build.bats
     ✓ yaml is installed for python
     ✓ homebrew is used in Linux if Pyenv is installed with Homebrew
     ✓ homebrew is not used in Linux if Pyenv is not installed with Homebrew
    
    3 tests, 0 failures

Writing test

To be reproducible, each test use/should use its own TMPDIR .
It's achieved by using the environment variable BATS_TEST_TMPDIR provided by bats that is automatically deleted at the end of each test. More info here

Another variable who could be used to source some file who need to be tested is BATS_TEST_DIRNAME who point to the directory in which the bats test file is located.