From 1bc10ec4850dde70d95798bd0f3926df305905ca Mon Sep 17 00:00:00 2001 From: coffeegoddd Date: Fri, 26 Jan 2024 14:11:31 -0800 Subject: [PATCH] /.github/{scripts,workflows}: add pull-report workflow, add script for updating readme with perf and correctness --- .github/scripts/update-perf.sh | 84 ++++++++++++++++++++++++++++++ .github/workflows/pull-report.yaml | 54 +++++++++++++++++++ README.md | 21 ++++++-- 3 files changed, 155 insertions(+), 4 deletions(-) create mode 100755 .github/scripts/update-perf.sh create mode 100644 .github/workflows/pull-report.yaml diff --git a/.github/scripts/update-perf.sh b/.github/scripts/update-perf.sh new file mode 100755 index 0000000000..1c0ea7c3cb --- /dev/null +++ b/.github/scripts/update-perf.sh @@ -0,0 +1,84 @@ +#!/bin/bash + +set -ex +set -o pipefail + +root="`dirname \"$0\"`" +dir="`realpath \"$root\"`" +doltgres_root="`realpath \"$dir/../../\"`" + +version="" +sed_cmd_i="" +start_marker="" +end_marker="" + +dest_file="$doltgres_root/README.md" +os_type="darwin" + +start_template='' +end_template='' + +if [ "$#" -ne 3 ]; then + echo "Must supply version and type, eg update-perf.sh 'v0.39.0' 'latency|correctness' '/path/to/file'" + exit 1; +fi + +version="$1" +type="$2" +new_table="$3" + +if [[ "$OSTYPE" == "linux-gnu"* ]]; then + os_type="linux" +fi + + +if [ "$type" == "latency" ] +then + # update the version + if [ "$os_type" == "linux" ] + then + sed -i 's/Here are the benchmarks for DoltgreSQL version `'".*"'`/Here are the benchmarks for DoltgreSQL version `'"$version"'`/' "$dest_file" + else + sed -i '' "s/Here are the benchmarks for DoltgreSQL version \\\`.*\\\`/Here are the benchmarks for DoltgreSQL version \\\`$version\\\`/" "$dest_file" + fi + + start_marker=$(printf "$start_template" "LATENCY") + end_marker=$(printf "$end_template" "LATENCY") + +else + # update the version + if [ "$os_type" == "linux" ] + then + sed -i 's/Here are DoltgreSQL'"'"'s sqllogictest results for version `'".*"'`./Here are DoltgreSQL'"'"'s sqllogictest results for version `'"$version"'`./' "$dest_file" + else + sed -i '' 's/Here are DoltgreSQL'"'"'s sqllogictest results for version `'".*"'`./Here are DoltgreSQL'"'"'s sqllogictest results for version `'"$version"'`./' "$dest_file" + fi + + start_marker=$(printf "$start_template" "CORRECTNESS") + end_marker=$(printf "$end_template" "CORRECTNESS") +fi + +# store in variable +updated=$(cat "$new_table") +updated_with_markers=$(printf "$start_marker\n$updated\n$end_marker\n") + +echo "$updated_with_markers" > "$new_table" + +if [ "$type" == "latency" ] +then + if [ "$os_type" == "linux" ] + then + sed -e '/ + +
# Correctness Dolt is [99.99% compatible](https://docs.dolthub.com/sql-reference/benchmarks/correctness) with MySQL based on a standard suite of correctness tests called `sqllogictest`. -A similar comparison for Doltgres coming soon. +We use these same tests to measure the correctness of DoltgreSQL. + +Here are DoltgreSQL's sqllogictest results for version `0.3.0`. Tests that +did not run could not complete due to a timeout earlier in the run. + + + +
# Architecture