Skip to content

Commit

Permalink
Run serum-dex unit tests
Browse files Browse the repository at this point in the history
  • Loading branch information
mvines committed Oct 23, 2020
1 parent 4e9ffe9 commit 9384a50
Show file tree
Hide file tree
Showing 4 changed files with 146 additions and 13 deletions.
24 changes: 24 additions & 0 deletions ci/buildkite-pipeline.sh
Original file line number Diff line number Diff line change
Expand Up @@ -175,6 +175,30 @@ EOF
"Stable-perf skipped as no relevant files were modified"
fi

# Downstream backwards compatibility
if affects \
.rs$ \
Cargo.lock$ \
Cargo.toml$ \
^ci/rust-version.sh \
^ci/test-stable-perf.sh \
^ci/test-stable.sh \
^ci/test-local-cluster.sh \
^core/build.rs \
^fetch-perf-libs.sh \
^programs/ \
^sdk/ \
^scripts/build-downstream-projects.sh \
; then
cat >> "$output_file" <<"EOF"
- command: "scripts/build-downstream-projects.sh"
name: "downstream-projects"
timeout_in_minutes: 30
EOF
else
annotate --style info \
"downstream-projects skipped as no relevant files were modified"
fi
# Benches...
if affects \
.rs$ \
Expand Down
107 changes: 107 additions & 0 deletions scripts/build-downstream-projects.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,107 @@
#!/usr/bin/env bash
#
# Builds known downstream projects against local solana source
#

set -e
cd "$(dirname "$0")"/..
source ci/_
source scripts/read-cargo-variable.sh

solana_ver=$(readCargoVariable version sdk/Cargo.toml)
solana_dir=$PWD

mkdir -p target/downstream-projects
cd target/downstream-projects

update_solana_dependencies() {
declare tomls=()
while IFS='' read -r line; do tomls+=("$line"); done < <(find "$1" -name Cargo.toml)

sed -i -e "s#\(solana-sdk = \"\).*\(\"\)#\1$solana_ver\2#g" "${tomls[@]}" || return $?
sed -i -e "s#\(solana-sdk = { version = \"\).*\(\"\)#\1$solana_ver\2#g" "${tomls[@]}" || return $?
sed -i -e "s#\(solana-client = \"\).*\(\"\)#\1$solana_ver\2#g" "${tomls[@]}" || return $?
}

update_spl_token_dependencies() {
declare tomls=()
while IFS='' read -r line; do tomls+=("$line"); done < <(find "$1" -name Cargo.toml)

declare spl_token_ver="$2"
sed -i -e "s#\(spl-token = { version = \"\).*\(\"\)#\1$spl_token_ver\2#g" "${tomls[@]}" || return $?
}

patch_crates_io() {
cat >> "$1" <<EOF
[patch.crates-io]
solana-client = { path = "$solana_dir/client"}
solana-sdk = { path = "$solana_dir/sdk" }
EOF
}

example_helloworld() {
(
set -x
rm -rf example-helloworld
git clone https://github.com/solana-labs/example-helloworld.git
cd example-helloworld

update_solana_dependencies src/program-rust
patch_crates_io src/program-rust/Cargo.toml
echo "[workspace]" >> src/program-rust/Cargo.toml

"$solana_dir"/cargo-build-bpf \
--manifest-path src/program-rust/Cargo.toml \
--no-default-features --features program

# TODO: Build src/program-c/...
)
}

spl() {
(
set -x
rm -rf spl
git clone https://github.com/solana-labs/solana-program-library.git spl
cd spl

update_solana_dependencies .
patch_crates_io Cargo.toml

"$solana_dir"/cargo-build-bpf \
--manifest-path memo/program/Cargo.toml \
--no-default-features --features program

"$solana_dir"/cargo-build-bpf \
--manifest-path token/program/Cargo.toml \
--no-default-features --features program
)
}

serum_dex() {
(
set -x
rm -rf serum-dex
git clone https://github.com/project-serum/serum-dex.git # TODO: Consider using a tag
cd serum-dex

update_solana_dependencies .
update_spl_token_dependencies . 2.0.8
patch_crates_io Cargo.toml
patch_crates_io dex/Cargo.toml
echo "[workspace]" >> dex/Cargo.toml

"$solana_dir"/cargo stable build

"$solana_dir"/cargo-build-bpf \
--manifest-path dex/Cargo.toml --no-default-features --features program

"$solana_dir"/cargo stable test \
--manifest-path dex/Cargo.toml --no-default-features --features program
)
}


_ example_helloworld
_ spl
_ serum_dex
14 changes: 1 addition & 13 deletions scripts/increment-cargo-version.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,19 +16,7 @@ EOF
here="$(dirname "$0")"
cd "$here"/..
source ci/semver_bash/semver.sh

readCargoVariable() {
declare variable="$1"
declare Cargo_toml="$2"

while read -r name equals value _; do
if [[ $name = "$variable" && $equals = = ]]; then
echo "${value//\"/}"
return
fi
done < <(cat "$Cargo_toml")
echo "Unable to locate $variable in $Cargo_toml" 1>&2
}
source scripts/read-cargo-variable.sh

ignores=(
.cache
Expand Down
14 changes: 14 additions & 0 deletions scripts/read-cargo-variable.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# source this file

readCargoVariable() {
declare variable="$1"
declare Cargo_toml="$2"

while read -r name equals value _; do
if [[ $name = "$variable" && $equals = = ]]; then
echo "${value//\"/}"
return
fi
done < <(cat "$Cargo_toml")
echo "Unable to locate $variable in $Cargo_toml" 1>&2
}

0 comments on commit 9384a50

Please sign in to comment.