Align atomic to 64 bytes to avoid false sharing. #310
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
on: [push, pull_request] | |
name: Integration tests | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
env: | |
RUSTFLAGS: "-D warnings" | |
CARGO_UNSTABLE_SPARSE_REGISTRY: true | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: dtolnay/rust-toolchain@nightly | |
- name: Create Cargo.lock file | |
run: cargo generate-lockfile | |
- name: Cache Cargo registry | |
uses: actions/cache@v3 | |
with: | |
path: ~/.cargo/registry | |
key: cargo-registry-${{ hashFiles('Cargo.toml') }}-${{ hashFiles('Cargo.lock') }} | |
restore-keys: | | |
cargo-registry-${{ hashFiles('Cargo.toml') }} | |
cargo-registry | |
- name: Check Cargo version | |
run: cargo -V > cargo.version.txt | |
- name: Cache Cargo target | |
uses: actions/cache@v3 | |
with: | |
path: target | |
key: cargo-target-release-${{ hashFiles('cargo.version.txt') }}-${{ hashFiles('Cargo.toml') }}-${{ hashFiles('Cargo.lock') }} | |
restore-keys: | | |
cargo-target-release-${{ hashFiles('cargo.version.txt') }}-${{ hashFiles('Cargo.toml') }} | |
cargo-target-release-${{ hashFiles('cargo.version.txt') }} | |
- name: Build STV-rs | |
run: cargo build --release | |
- name: Build histogram | |
run: cargo build --release --example histogram | |
- name: Build remove_nicknames | |
run: cargo build --release --example remove_nicknames | |
- name: Build shuffle_ballots | |
run: cargo build --release --example shuffle_ballots | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: build-artifacts | |
path: | | |
target/release/stv-rs | |
target/release/examples/histogram | |
target/release/examples/remove_nicknames | |
target/release/examples/shuffle_ballots | |
if-no-files-found: error | |
- name: Generate random ballots | |
run: | | |
cargo run --release --example random_ballots | |
mv rand_hypergeometric_100k.blt testdata/ballots/random/ | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: large-test-files | |
path: | | |
testdata/ballots/random/rand_hypergeometric_100k.blt | |
if-no-files-found: error | |
help_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- short_help | |
- help | |
- meek_help | |
- plurality_help | |
- version | |
include: | |
- file: short_help | |
flags: "-h" | |
- file: help | |
flags: "--help" | |
- file: meek_short_help | |
flags: "meek -h" | |
- file: meek_help | |
flags: "meek --help" | |
- file: plurality_help | |
flags: "plurality --help" | |
- file: version | |
flags: "--version" | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- name: Prepare STV-rs binary | |
run: chmod +x target/release/stv-rs | |
- name: Check output | |
run: | | |
target/release/stv-rs ${{ matrix.flags }} | diff -s man/${{ matrix.file }}.txt - | |
meek_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- equal_preference/equal_preference | |
- equal_preference/equal_preference_droop | |
- equal_preference/equal_preference_equalize | |
- negative_surplus/below_quota | |
- random/rand_2x10 | |
- random/rand_5x4 | |
- random/rand_hypergeometric | |
- random/rand_hypergeometric_10k | |
- random/rand_hypergeometric_100k | |
- recursive_descent/transfer | |
- recursive_descent/transfer_is_blocked | |
- ties/tie_break_explicit | |
- ties/tie_break_implicit | |
- skewed | |
- vegetables | |
parallel: | |
- no | |
- rayon | |
- custom | |
include: | |
- droop: true | |
- file: random/rand_hypergeometric_10k | |
droop: false | |
- file: random/rand_hypergeometric_100k | |
droop: false | |
- file: skewed | |
droop: false | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- uses: actions/download-artifact@v3 | |
with: | |
name: large-test-files | |
path: testdata/ballots/random/ | |
- name: Install Droop | |
if: ${{ matrix.parallel == 'rayon' }} | |
run: git clone https://github.com/jklundell/droop | |
- name: Prepare STV-rs binary | |
run: chmod +x target/release/stv-rs | |
- name: Check STV-rs output (ballot from stdin) | |
run: | | |
target/release/stv-rs --arithmetic fixed9 meek --parallel=${{ matrix.parallel }} < testdata/ballots/${{ matrix.file }}.blt | diff -s testdata/meek/${{ matrix.file }}.fixed9.log - | |
- name: Check STV-rs output (ballot from CLI) | |
run: | | |
target/release/stv-rs --arithmetic fixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --parallel=${{ matrix.parallel }} | diff -s testdata/meek/${{ matrix.file }}.fixed9.log - | |
- name: Check STV-rs output (equalized counting) | |
run: | | |
target/release/stv-rs --arithmetic fixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --parallel=${{ matrix.parallel }} --equalize | diff -s testdata/meek/${{ matrix.file }}.equalize.fixed9.log - | |
- name: Check Droop output | |
if: matrix.droop == true && matrix.parallel == 'rayon' | |
run: | | |
sed -i "s/Implementation: STV-rs/Droop package: droop v0.14/g" testdata/meek/${{ matrix.file }}.fixed9.log | |
python3 droop/Droop.py meek fixed precision=9 omega=6 defeat_batch=none testdata/ballots/${{ matrix.file }}.blt 2> droop.err | diff -s testdata/meek/${{ matrix.file }}.fixed9.log - | |
echo -n "" | diff -s - droop.err | |
plurality_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- random/rand_2x10 | |
- random/rand_5x4 | |
- random/rand_hypergeometric | |
- random/rand_hypergeometric_10k | |
- random/rand_hypergeometric_100k | |
- vegetables | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- uses: actions/download-artifact@v3 | |
with: | |
name: large-test-files | |
path: testdata/ballots/random/ | |
- name: Prepare STV-rs binary | |
run: chmod +x target/release/stv-rs | |
- name: Check STV-rs output | |
run: | | |
target/release/stv-rs --arithmetic fixed9 plurality < testdata/ballots/${{ matrix.file }}.blt | diff -s testdata/plurality_block_voting/${{ matrix.file }}.fixed9.log - | |
histogram_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- bigint/ballot_count_overflows | |
- bigint/ballot_sum_overflows | |
- bigint/rand_hypergeometric_many | |
- equal_preference/equal_preference | |
- random/rand_2x10 | |
- random/rand_5x4 | |
- random/rand_hypergeometric | |
- random/rand_hypergeometric_10k | |
- random/rand_hypergeometric_100k | |
- vegetables | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- uses: actions/download-artifact@v3 | |
with: | |
name: large-test-files | |
path: testdata/ballots/random/ | |
- name: Prepare histogram binary | |
run: chmod +x target/release/examples/histogram | |
- name: Check histogram output | |
run: | | |
target/release/examples/histogram < testdata/ballots/${{ matrix.file }}.blt | diff -s testdata/histogram/${{ matrix.file }}.csv - | |
surplus_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- negative_surplus/below_quota | |
parallel: | |
- no | |
- rayon | |
- custom | |
include: | |
- file: negative_surplus/below_quota | |
output: negative_surplus/force_positive_surplus | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- name: Prepare STV-rs binary | |
run: chmod +x target/release/stv-rs | |
- name: Check STV-rs output | |
run: | | |
target/release/stv-rs --arithmetic fixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --parallel=${{ matrix.parallel }} --force-positive-surplus | diff -s testdata/meek/${{ matrix.output }}.fixed9.log - | |
numeric_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- equal_preference | |
- vegetables.keep_withdrawn | |
- vegetables.remove_withdrawn | |
include: | |
- file: equal_preference | |
src: equal_preference/equal_preference | |
flags: "" | |
- file: vegetables.keep_withdrawn | |
src: vegetables | |
flags: "" | |
- file: vegetables.remove_withdrawn | |
src: vegetables | |
flags: "--remove-withdrawn-candidates" | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- name: Install Droop | |
if: ${{ matrix.flags == '' }} | |
run: git clone https://github.com/jklundell/droop | |
- name: Prepare remove_nicknames binary | |
run: chmod +x target/release/examples/remove_nicknames | |
- name: Check numeric ballot | |
run: | | |
target/release/examples/remove_nicknames ${{ matrix.flags }} < testdata/ballots/${{ matrix.src }}.blt | diff -s testdata/numeric/${{ matrix.file }}.blt - | |
- name: Check Droop output | |
if: ${{ matrix.flags == '' }} | |
run: | | |
sed -i "s/Implementation: STV-rs/Droop package: droop v0.14/g" testdata/meek/${{ matrix.src }}.fixed9.log | |
python3 droop/Droop.py meek fixed precision=9 omega=6 defeat_batch=none testdata/numeric/${{ matrix.file }}.blt 2> droop.err | diff -s testdata/meek/${{ matrix.src }}.fixed9.log - | |
echo -n "" | diff -s - droop.err | |
shuffle_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- rand_sorted_by_product | |
- rand_sorted_lexicographically | |
- rand_sorted_by_lexico_product | |
- rand_10k_sorted_by_product | |
- rand_10k_sorted_lexicographically | |
- rand_10k_sorted_by_lexico_product | |
include: | |
- file: rand_sorted_by_product | |
src: random/rand_hypergeometric | |
strategy: "product" | |
- file: rand_sorted_lexicographically | |
src: random/rand_hypergeometric | |
strategy: "lexicographic" | |
- file: rand_sorted_by_lexico_product | |
src: random/rand_hypergeometric | |
strategy: "lexico-product" | |
- file: rand_10k_sorted_by_product | |
src: random/rand_hypergeometric_10k | |
strategy: "product" | |
- file: rand_10k_sorted_lexicographically | |
src: random/rand_hypergeometric_10k | |
strategy: "lexicographic" | |
- file: rand_10k_sorted_by_lexico_product | |
src: random/rand_hypergeometric_10k | |
strategy: "lexico-product" | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- name: Prepare shuffle_ballots binary | |
run: chmod +x target/release/examples/shuffle_ballots | |
- name: Check shuffled ballot | |
run: | | |
target/release/examples/shuffle_ballots --strategy=${{ matrix.strategy }} < testdata/ballots/${{ matrix.src }}.blt | diff -s testdata/shuffle_ballots/${{ matrix.file }}.blt - | |
bigint_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- bigint/ballot_count_overflows | |
- bigint/ballot_sum_overflows | |
- bigint/rand_hypergeometric_many | |
parallel: | |
- no | |
- rayon | |
- custom | |
include: | |
- error_suffix: "" | |
- equalize: false | |
- file: bigint/ballot_sum_overflows | |
parallel: rayon | |
error_suffix: ".rayon" | |
- file: bigint/ballot_sum_overflows | |
parallel: custom | |
error_suffix: ".custom" | |
- file: bigint/rand_hypergeometric_many | |
equalize: true | |
fail-fast: false | |
runs-on: ubuntu-latest | |
env: | |
RAYON_NUM_THREADS: 1 | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- name: Prepare STV-rs binary | |
run: chmod +x target/release/stv-rs | |
- name: Check STV-rs output | |
if: ${{ matrix.equalize == false }} | |
run: | | |
target/release/stv-rs --arithmetic fixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --num-threads=1 --parallel=${{ matrix.parallel }} > stv.log 2> stv.err || true | |
diff -s testdata/meek/${{ matrix.file }}.fixed9.log stv.log | |
diff -s testdata/meek/${{ matrix.file }}.fixed9${{ matrix.error_suffix }}.err stv.err | |
- name: Check STV-rs output (big integer) | |
if: ${{ matrix.equalize == false }} | |
run: | | |
target/release/stv-rs --arithmetic bigfixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --num-threads=1 --parallel=${{ matrix.parallel }} > stv.log 2> stv.err || true | |
diff -s testdata/meek/${{ matrix.file }}.bigfixed9.log stv.log | |
diff -s testdata/meek/${{ matrix.file }}.bigfixed9.err stv.err | |
- name: Check STV-rs output (equalized counting) | |
if: ${{ matrix.equalize == true }} | |
run: | | |
target/release/stv-rs --arithmetic fixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --equalize --num-threads=1 --parallel=${{ matrix.parallel }} > stv.log 2> stv.err || true | |
diff -s testdata/meek/${{ matrix.file }}.equalize.fixed9.log stv.log | |
diff -s testdata/meek/${{ matrix.file }}.equalize.fixed9${{ matrix.error_suffix }}.err stv.err | |
- name: Check STV-rs output (equalized counting, big integer) | |
if: ${{ matrix.equalize == true }} | |
run: | | |
target/release/stv-rs --arithmetic bigfixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --equalize --num-threads=1 --parallel=${{ matrix.parallel }} > stv.log 2> stv.err || true | |
diff -s testdata/meek/${{ matrix.file }}.equalize.bigfixed9.log stv.log | |
diff -s testdata/meek/${{ matrix.file }}.equalize.bigfixed9.err stv.err | |
crash_fixed9_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- crashes/crash | |
- crashes/minimal | |
- crashes/minimal10 | |
- crashes/rand_geometric | |
parallel: | |
- no | |
- rayon | |
- custom | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- name: Prepare STV-rs binary | |
run: chmod +x target/release/stv-rs | |
- name: Check STV-rs output | |
run: | | |
target/release/stv-rs --arithmetic fixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --parallel=${{ matrix.parallel }} --force-positive-surplus | diff -s testdata/meek/${{ matrix.file }}.fixed9.log - | |
- name: Check STV-rs output (equalized counting) | |
run: | | |
target/release/stv-rs --arithmetic fixed9 --input testdata/ballots/${{ matrix.file }}.blt meek --parallel=${{ matrix.parallel }} --force-positive-surplus --equalize | diff -s testdata/meek/${{ matrix.file }}.equalize.fixed9.log - | |
crash_approx_tests: | |
needs: build | |
strategy: | |
matrix: | |
file: | |
- crashes/elect_too_many | |
parallel: | |
- no | |
- rayon | |
- custom | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: build-artifacts | |
path: target/release/ | |
- name: Prepare STV-rs binary | |
run: chmod +x target/release/stv-rs | |
- name: Check STV-rs output | |
run: | | |
target/release/stv-rs --arithmetic approx --input testdata/ballots/${{ matrix.file }}.blt meek --parallel=${{ matrix.parallel }} | diff -s testdata/meek/${{ matrix.file }}.approx.log - | |
- name: Check STV-rs output (equalized counting) | |
run: | | |
target/release/stv-rs --arithmetic approx --input testdata/ballots/${{ matrix.file }}.blt meek --parallel=${{ matrix.parallel }} --equalize | diff -s testdata/meek/${{ matrix.file }}.equalize.approx.log - | |
crash_droop_tests: | |
strategy: | |
matrix: | |
file: | |
- crashes/crash | |
- crashes/elect_too_many | |
- crashes/minimal | |
- crashes/minimal10 | |
- crashes/rand_geometric | |
fail-fast: false | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install Droop | |
run: git clone https://github.com/jklundell/droop | |
- name: Check that Droop fails | |
run: | | |
python3 droop/Droop.py meek fixed precision=9 omega=6 defeat_batch=none testdata/ballots/${{ matrix.file }}.blt > droop.log 2> droop.err || true | |
diff -s testdata/meek/${{ matrix.file }}.droop.err droop.err | |
echo -n "" | diff -s - droop.log |