-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy path.justfile
58 lines (39 loc) · 1.55 KB
/
.justfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# For use with the just command runner, https://just.systems/
export LLVM_PROFILE_FILE := 'coverage/cargo-test-%p-%m.profraw'
default:
@just --list
grcov:
@echo 'Running tests for coverage with grcov'
rm -rf ${CARGO_TARGET_DIR}/coverage
CARGO_INCREMENTAL=0 RUSTFLAGS='-Cinstrument-coverage' cargo test
grcov . --binary-path ${CARGO_TARGET_DIR}/debug/deps/ \
-s . -t html \
--branch \
--ignore-not-existing --ignore '../*' --ignore "/*" \
-o ${CARGO_TARGET_DIR}/coverage
@echo grcov report in file://${CARGO_TARGET_DIR}/coverage/index.html
coverage-tarpaulin:
@echo 'Running tests for coverage with tarpaulin'
mkdir /tmp/tarpaulin
cargo tarpaulin --engine llvm --line --out html --output-dir /tmp/tarpaulin
setup-coverage-tools:
rustup component add llvm-tools-preview
cargo install grcov
cargo install cargo-tarpaulin
# Builds with the mold linker are faster (for Linux/AMD64)
moldy-build:
mold -run cargo build
# Compiling the openssl crate on Android is complicated so we use the rustls-tls feature. Avoid some
# typing on tiny keyboards.
termux:
cargo update
cargo test --no-default-features --features fetch,rustls-tls,compression,scte35 -- --show-output
# Run a trivy vulnerability scan of this repository
# https://github.com/aquasecurity/trivy
trivy-repository:
podman run -v $PWD:/myapp docker.io/aquasec/trivy fs --scanners vuln,secret,misconfig .
clippy:
cargo clippy -- -Wclippy::unwrap_used -Wclippy::expect_used -Wclippy::indexing_slicing -Wclippy::panic
publish:
cargo test
cargo publish