forked from nakabonne/rhack
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path.justfile
194 lines (152 loc) · 5.72 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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
################################################################################
# Justfile #
# #
# Set of routines to execute for development work. #
# #
# To make use of this file install: https://crates.io/crates/just #
# #
################################################################################
# 'Just' Configuration
# Loads .env file for variables to be used in
# in this just file
set dotenv-load
default:
just --choose
# Ignore recipes that are commented out
set ignore-comments := true
# Set shell for Windows OSs:
# If you have PowerShell Core installed and want to use it,
# use `pwsh.exe` instead of `powershell.exe`
set windows-shell := ["powershell.exe", "-NoLogo", "-Command"]
# Set shell for non-Windows OSs:
set shell := ["bash", "-uc"]
# Runs the benchmark suite
# bench *ARGS:
# cargo +nightly bench {{ARGS}}
# Builds the library.
# build:
# cargo build --no-default-features
# cargo build --all-features
# @cargo build --all-features --example sieve
# @cargo build --all-features --example tour
# Checks the library for syntax and HIR errors.
check:
cargo check --no-default-features
cargo check --all-features
# Runs all of the recipes necessary for pre-publish.
# checkout: format check lint build doc test package
# Continually runs the development routines.
ci:
just loop dev
# Removes all build artifacts.
clean:
cargo clean
# Runs the development routines.
dev: format lint doc test
# Opens the crate documentation.
# @cargo +nightly doc --all-features {{ARGS}}
# @cargo doc --all-features --no-deps --open {{ARGS}}
doc *CRATE:
@cargo doc --all-features --no-deps {{CRATE}}
# Format all code
fmt:
@just format
@dprint fmt
# Runs the formatter on all Rust files.
format:
@cargo +nightly fmt --all
# Runs the linter.
lint: check
cargo clippy --no-default-features
cargo clippy --all-features
# Continually runs some recipe from this file.
loop action:
watchexec -w src -- "just {{action}}"
# Looks for undefined behavior in the (non-doc) test suite.
miri *TESTS:
cargo +nightly miri test --all-features -q --lib --tests {{TESTS}}
# Packages the crate in preparation for publishing on crates.io
# package:
# cargo package --allow-dirty
# Publishes the crate to crates.io
# publish: checkout
# cargo publish
# Runs the test suites.
test: check lint
cargo nextest run --all-features --workspace
# Runs the test suites.
dtest: check lint
cargo test --doc --workspace
# Runs the whole test suite with nextest.
ntest:
cargo nextest run --all-features --workspace
# Runs only the ignored tests with nextest.
nitest:
cargo nextest run --all-features --workspace -- --ignored
# Runs a test defined by an expression with nextest.
# e.g. `just ntest completions` => test completions
natest *TEST:
cargo nextest run --all-features --workspace -E 'test({{TEST}})'
# list the inverse dependencies
# as in which feature enables a given crate
inv-ft *PACKAGE:
cargo tree -e features -i {{PACKAGE}}
# prepare for making a PR
pr:
just fmt lint test
# prepare for making a PR (expensive)
ex-pr:
just pr
just check-powerset pace_core
just test-powerset pace_core
just coverage
# Run the test suite with coverage for the given package
p-coverage *PACKAGE:
cargo tarpaulin --all-features -p {{PACKAGE}} --output-dir coverage/ -o Lcov
# Run the test suite with coverage for the workspace
ws-coverage:
cargo tarpaulin --all-features --workspace --output-dir coverage/ -o Lcov
# Run the test suite with coverage for the packages we care about
coverage:
just p-coverage pace_core
# Run checks with feature powerset
check-powerset *PACKAGE:
cargo hack check --feature-powerset -p {{PACKAGE}}
# Run checks with feature powerset
test-powerset *PACKAGE:
cargo hack test --feature-powerset -p {{PACKAGE}}
# Update the scoop manifest from the given version to the latest on crates.io
update-scoop-manifest:
sd $env:RHACK_CURRENT_VERSION $(xh get https://crates.io/api/v1/crates/cargo-rhack | jq .crate.max_version) scoop/cargo-rhack.json
sd $env:RHACK_CURRENT_VERSION $(xh get https://crates.io/api/v1/crates/cargo-rhack | jq .crate.max_version) .env
# Run insta tests in review mode
insta:
cargo insta test --review --workspace
# Create a new tag for the current version on crates.io to make cargo-dist create a new release
tag-release:
git tag -a cargo-rhack-v$(xh get https://crates.io/api/v1/crates/cargo-rhack | jq .crate.max_version)
git push origin cargo-rhack-v$(xh get https://crates.io/api/v1/crates/cargo-rhack | jq .crate.max_version)
# Make the most recent version from crates.io the latest release on GitHub
make-latest:
gh release edit cargo-rhack-v$(xh get https://crates.io/api/v1/crates/cargo-rhack | jq .crate.max_version) --latest
bloat-deps *PACKAGE:
cargo bloat --release --crates -p {{PACKAGE}}
bloat-time *PACKAGE:
cargo bloat --release --time -j 1 -p {{PACKAGE}}
install-dev-deps:
cargo install cargo-hack
cargo install cargo-nextest
cargo install cargo-tarpaulin
# cargo install dprint # if you want to use formatting with dprint
# cargo install gh # if you want to use github cli
cargo install sd
cargo install cargo-watch
# cargo install xh # if you want to use xh for updating scoop manifest
cargo install cargo-bloat
cargo install cargo-mutants
cargo install cargo-fuzz
rustup component add llvm-tools-preview
# Run cargo build with timings
# use `html` or `json` as ARGS
timings *ARGS:
cargo +nightly build --release --timings={{ARGS}} -Z unstable-options