docs: adding a testing infos file to guide everyone through tests

This commit is contained in:
MartinFillon 2024-05-06 17:59:25 +02:00 committed by Christina Sørensen
parent 7e155d4150
commit 7edce99d81
2 changed files with 40 additions and 3 deletions

View file

@ -21,7 +21,7 @@ It is strongly recommended that you install Nix for hacking on eza. We leverage
nix as a way to easily test and distribute eza to many users, and it allows us
to provide multiple tools easily for developers. Instead of having to install
each dependency manually and setting up a development environment, Nix allows
you to use the same environment as the devs use.
you to use the same environment as the devs use.
Therefore, it is useful that you have a version of Nix installed with the
"experimental" feature flakes enabled. Further, to make hacking on eza as easy
@ -66,7 +66,7 @@ directory.
eza depends on [libgit2](https://github.com/rust-lang/git2-rs) for certain
features. If youre unable to compile libgit2, you can opt out of Git support
by running `cargo build --no-default-features`. Again, the nix flake should
by running `cargo build --no-default-features`. Again, the nix flake should
have taken care of this for you, if not, please file an issue.
If you intend to compile for musl, you will need to use the flag
@ -74,13 +74,16 @@ If you intend to compile for musl, you will need to use the flag
is `cargo build --release --target=x86_64-unknown-linux-musl --features
vendored-openssl,git`.
If you want more information on the tests please read:
[testing on eza](https://github.com/eza-community/eza/blob/main/TESTING.md)
## Creating a PR
First, use the pull request template.
Please make sure that the thing you worked on... actually works. Make sure to
also add how you ensured this in the PR description. Further, it's expected
that you do your best to check for regressions.
that you do your best to check for regressions.
If your PR introduces a flag, you MUST:
- Add completions for bash, zsh, fish, nushell

34
TESTING.md Normal file
View file

@ -0,0 +1,34 @@
<!--
SPDX-FileCopyrightText: 2024 Christina Sørensen, Martin Fillon
SPDX-FileContributor: Christina Sørensen
SPDX-License-Identifier: EUPL-1.2
-->
# Testing eza
## Running tests
In order to run the tests in eza you need:
- [just](https://github.com/casey/just)
- [nix](https://nixos.org)
then either run:
- `just itest`
- `nix build -L trycmd-local`
## Modifying tests
In order to test your changes on eza, you will need to do one or multiple things in different cases.
You will need the additional tool
- [powertest](https://github.com/eza-community/powertest)
You will also need to modify the `devtools/dir-generator.sh` file if you want to add some test cases
### You added/modified an option
Please run `just regen` to regenerate powertesting. Then look into `tests/gen` or `tests/cmd` for any tests not passing
### You changed the output of eza
Please run `nix build -L trydump` or `just idump`
And lookout for any test no longer passing