diff --git a/.github/workflows/run-tests.yaml b/.github/workflows/run-tests.yaml new file mode 100644 index 0000000..839421b --- /dev/null +++ b/.github/workflows/run-tests.yaml @@ -0,0 +1,17 @@ +name: Run tests +run-name: Run tests +on: + push: + branches: [ main ] + pull_request: + branches: [ main ] + +jobs: + run-tests: + runs-on: ubuntu-22.04 + steps: + - name: Check out source Repo + uses: actions/checkout@v3 + + - name: Run tests in container image + run: docker run --rm -i $(docker build -q -f Dockerfile.test .) diff --git a/Dockerfile b/Dockerfile index fca0812..cb75c89 100644 --- a/Dockerfile +++ b/Dockerfile @@ -8,7 +8,10 @@ COPY ./Cargo.toml . COPY ./Cargo.lock . COPY ./rust-toolchain.toml . COPY ./x86_64-os.json . +COPY ./tests ./tests +RUN apt-get update && \ + apt-get install qemu-system -y RUN cargo install bootimage && \ rustup component add rust-src --toolchain nightly-aarch64-unknown-linux-gnu && \ rustup component add llvm-tools-preview diff --git a/Dockerfile.test b/Dockerfile.test new file mode 100644 index 0000000..3baef14 --- /dev/null +++ b/Dockerfile.test @@ -0,0 +1,22 @@ +FROM rust:1.73-slim-bullseye + +WORKDIR /builder + +COPY ./.cargo ./.cargo +COPY ./src ./src +COPY ./Cargo.toml . +COPY ./Cargo.lock . +COPY ./rust-toolchain.toml . +COPY ./x86_64-os.json . +COPY ./tests ./tests + +RUN apt-get update && \ + apt-get install qemu-system -y +RUN cargo install bootimage && \ + rustup target add aarch64-unknown-linux-gnu && \ + rustup toolchain install nightly-aarch64-unknown-linux-gnu && \ + rustup component add rust-src --toolchain nightly-aarch64-unknown-linux-gnu && \ + rustup component add rust-src --toolchain nightly-x86_64-unknown-linux-gnu && \ + rustup component add llvm-tools-preview + +CMD ["cargo","test"] diff --git a/README.md b/README.md index 2b244d7..44a5e3f 100644 --- a/README.md +++ b/README.md @@ -39,3 +39,17 @@ Hobby OS implementation in Rust ```bash qemu-system-x86_64 -drive format=raw,file=target/x86_64-os/debug/bootimage-os.bin ``` + +## Tests + +Run tests in Docker: + +```bash +docker run --rm -it $(docker build -q -f Dockerfile.test .) +``` + +Run tests on host system: + +```bash +cargo test +``` diff --git a/src/main.rs b/src/main.rs index f7996e4..6972072 100644 --- a/src/main.rs +++ b/src/main.rs @@ -42,5 +42,5 @@ fn panic(info: &PanicInfo) -> ! { #[test_case] fn trivial_assertion() { - assert_eq!(1, 1); + assert_eq!(1, 0); }