-
Notifications
You must be signed in to change notification settings - Fork 103
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: remove earthly usage for benchmarks #654
Changes from 1 commit
db8fa2f
5108107
221c26d
7d5aefe
ab6def2
ddeb433
63cca4c
5d4d32d
40321e1
83da574
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -101,6 +101,7 @@ | |
just | ||
nodejs_22 | ||
self.packages.${system}.speakeasy | ||
goperf | ||
]; | ||
}; | ||
} | ||
|
This file was deleted.
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,15 +6,15 @@ const main = async () => { | |
let buffer = fs.readFileSync('../report/report.json', 'utf-8'); | ||
let reports = JSON.parse(buffer); | ||
await exportTPSGraph({ | ||
output: 'tps.png', | ||
output: '../report/tps.png', | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 💡 Codebase verification Directory creation check is required The codebase lacks directory existence verification before file operations. The suggested change to create the '../report' directory is necessary to prevent runtime errors.
if (!fs.existsSync('../report')) {
fs.mkdirSync('../report', { recursive: true });
} 🔗 Analysis chainVerify report directory existence before file operations. While the path changes are consistent, ensure the '../report' directory exists before writing files to prevent runtime errors. Consider adding directory creation: const main = async () => {
+ // Ensure report directory exists
+ if (!fs.existsSync('../report')) {
+ fs.mkdirSync('../report', { recursive: true });
+ }
let buffer = fs.readFileSync('../report/report.json', 'utf-8'); Also applies to: 12-12, 17-17 🏁 Scripts executedThe following scripts were executed for the analysis: Error: No shell scripts found Script: #!/bin/bash
# Check the content of the test file
cat test/performance/charts/index.ts
# Search for directory creation patterns in related files
rg -l "mkdirSync.*report" --type ts
# Look for fs operations in test setup
rg "fs\.(mkdir|existsSync)" --type ts
Length of output: 778 Script: #!/bin/bash
# Check for test runner configuration
fd -e json package.json --exec cat {}
# Look for test setup files
fd -e ts -e js setup test/performance --exec cat {}
Length of output: 650 |
||
}, reports); | ||
|
||
await exportDatabaseStats('database_connections.png', reports); | ||
await exportDatabaseStats('../report/database_connections.png', reports); | ||
|
||
const ps: (keyof MetricsTime)[] = ['P99', 'P95', 'P75', 'Avg'] | ||
for (let p of ps) { | ||
await exportLatencyGraph({ | ||
output: p.toLowerCase() + '.png' | ||
output: '../report/' + p.toLowerCase() + '.png' | ||
}, p, reports); | ||
} | ||
} | ||
|
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
@@ -0,0 +1,33 @@ | ||||||||||||||||||||||||||||||||||||||||||||||
set dotenv-load | ||||||||||||||||||||||||||||||||||||||||||||||
set positional-arguments | ||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||
tmpdir := `mktemp -d` | ||||||||||||||||||||||||||||||||||||||||||||||
gfyrag marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||
run bench='.' p='1' benchtime='1s' count='1' ledger-url='' output='./report/benchmark-output.txt': | ||||||||||||||||||||||||||||||||||||||||||||||
rm -f {{output}} | ||||||||||||||||||||||||||||||||||||||||||||||
go test -run ^$ -tags it,local \ | ||||||||||||||||||||||||||||||||||||||||||||||
-report.file ./report/report.json \ | ||||||||||||||||||||||||||||||||||||||||||||||
-timeout 60m \ | ||||||||||||||||||||||||||||||||||||||||||||||
-bench={{bench}} \ | ||||||||||||||||||||||||||||||||||||||||||||||
-count={{count}} \ | ||||||||||||||||||||||||||||||||||||||||||||||
--ledger.url={{ledger-url}} \ | ||||||||||||||||||||||||||||||||||||||||||||||
-p {{p}} \ | ||||||||||||||||||||||||||||||||||||||||||||||
-test.benchtime {{benchtime}} . | tee -a {{output}} | ||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||
compare bench='.' p='1' benchtime='1s' count='1' output='./report/benchmark-output.txt': | ||||||||||||||||||||||||||||||||||||||||||||||
just run {{bench}} {{p}} {{benchtime}} {{count}} '' './report/benchmark-output-local.txt' | ||||||||||||||||||||||||||||||||||||||||||||||
git clone --depth 1 -b main https://github.com/formancehq/ledger {{tmpdir}} | ||||||||||||||||||||||||||||||||||||||||||||||
go test -run ^$ -tags it,local -report.file \ | ||||||||||||||||||||||||||||||||||||||||||||||
./report/report.json \ | ||||||||||||||||||||||||||||||||||||||||||||||
-timeout 60m \ | ||||||||||||||||||||||||||||||||||||||||||||||
-bench={{bench}} \ | ||||||||||||||||||||||||||||||||||||||||||||||
-count={{count}} \ | ||||||||||||||||||||||||||||||||||||||||||||||
-p {{p}} \ | ||||||||||||||||||||||||||||||||||||||||||||||
-test.benchtime {{benchtime}} \ | ||||||||||||||||||||||||||||||||||||||||||||||
{{tmpdir}}/test/performance | tee -a ./report/benchmark-output-main.txt | ||||||||||||||||||||||||||||||||||||||||||||||
benchstat ./report/benchmark-output-main.txt ./report/benchmark-output-local.txt > ./report/benchmark-comparison.txt || true | ||||||||||||||||||||||||||||||||||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 🛠️ Refactor suggestion Improve error handling in comparison workflow. The current implementation has two issues:
Consider this improved error handling: compare bench='.' p='1' benchtime='1s' count='1' output='./report/benchmark-output.txt':
just run {{bench}} {{p}} {{benchtime}} {{count}} '' './report/benchmark-output-local.txt'
- git clone --depth 1 -b main https://github.com/formancehq/ledger {{tmpdir}}
+ git clone --depth 1 -b main https://github.com/formancehq/ledger {{tmpdir}} || exit 1
go test -run ^$ -tags it,local -report.file \
./report/report.json \
-timeout 60m \
-bench={{bench}} \
-count={{count}} \
-p {{p}} \
-test.benchtime {{benchtime}} \
{{tmpdir}}/test/performance | tee -a ./report/benchmark-output-main.txt
- benchstat ./report/benchmark-output-main.txt ./report/benchmark-output-local.txt > ./report/benchmark-comparison.txt || true
+ if ! benchstat ./report/benchmark-output-main.txt ./report/benchmark-output-local.txt > ./report/benchmark-comparison.txt; then
+ echo "Warning: benchstat failed to generate comparison" >&2
+ fi 📝 Committable suggestion
Suggested change
|
||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||
graphs: | ||||||||||||||||||||||||||||||||||||||||||||||
cd charts && npm install | ||||||||||||||||||||||||||||||||||||||||||||||
cd charts && npm run build | ||||||||||||||||||||||||||||||||||||||||||||||
cd charts && node ./index.js | ||||||||||||||||||||||||||||||||||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ./index.ts ? Because index.js is removed There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. after the npm run build above, it exists |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If there isn't this part, and the benchmarks go wrong for X or Y reason, the Ledger will continue to work and won't be cut.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The ledger is run via the test, not externally