From 7b480f285f7532d9a240acfa0a74d45065bf5fd4 Mon Sep 17 00:00:00 2001 From: Daniel Lundin Date: Thu, 12 Sep 2024 22:34:19 +0200 Subject: [PATCH 1/2] Add justfile --- flake.nix | 111 ++++++++++++++++++++++++++++-------------------------- justfile | 16 ++++++++ 2 files changed, 74 insertions(+), 53 deletions(-) create mode 100644 justfile diff --git a/flake.nix b/flake.nix index d62d9c3..060ae42 100644 --- a/flake.nix +++ b/flake.nix @@ -5,66 +5,71 @@ nixpkgs.url = "github:nixos/nixpkgs?ref=nixos-unstable"; }; - outputs = { self, nixpkgs }: { - lib = { - # Prepare a ready-to-boot disk image. - mkInstallImage = nixos: - let - config = nixos.config; - pkgs = nixpkgs.legacyPackages.x86_64-linux.pkgs; - in - nixos.pkgs.runCommand "update-${config.system.image.version}" - { - nativeBuildInputs = with pkgs; [ qemu ]; - } '' - mkdir -p $out - qemu-img convert -f raw -O qcow2 -C ${config.system.build.image}/${config.boot.uki.name}_${config.system.image.version}.raw $out/disk.qcow2 - ''; - }; - - devShells.x86_64-linux.default = - let - pkgs = nixpkgs.legacyPackages.x86_64-linux; - in - pkgs.mkShell { - packages = [ - self.packages.x86_64-linux.qemu-efi - ]; + outputs = + { self, nixpkgs }: + { + lib = { + # Prepare a ready-to-boot disk image. + mkInstallImage = + nixos: + let + config = nixos.config; + pkgs = nixpkgs.legacyPackages.x86_64-linux.pkgs; + in + nixos.pkgs.runCommand "update-${config.system.image.version}" + { + nativeBuildInputs = with pkgs; [ qemu ]; + } + '' + mkdir -p $out + qemu-img convert -f raw -O qcow2 -C ${config.system.build.image}/${config.boot.uki.name}_${config.system.image.version}.raw $out/disk.qcow2 + ''; }; - packages.x86_64-linux = { - default = self.packages.x86_64-linux.patos_image; - - patos_image = self.lib.mkInstallImage self.nixosConfigurations.patos; - - # A helper script to run the disk images above. - qemu-efi = + devShells.x86_64-linux.default = let pkgs = nixpkgs.legacyPackages.x86_64-linux; in - pkgs.writeShellApplication { - name = "qemu-efi"; - - runtimeInputs = [ pkgs.qemu_kvm ]; - - text = '' - qemu-system-x86_64 \ - -smp 2 -m 2048 -machine q35,accel=kvm \ - -bios ${pkgs.OVMF.fd}/FV/OVMF.fd \ - -snapshot \ - -display none \ - -serial stdio "$@" - ''; + pkgs.mkShell { + packages = [ + pkgs.just + self.packages.x86_64-linux.qemu-efi + ]; }; - }; - nixosConfigurations = { - patos = nixpkgs.lib.nixosSystem { - system = "x86_64-linux"; - modules = [ - ./base.nix - ]; + packages.x86_64-linux = { + default = self.packages.x86_64-linux.patos_image; + + patos_image = self.lib.mkInstallImage self.nixosConfigurations.patos; + + # A helper script to run the disk images above. + qemu-efi = + let + pkgs = nixpkgs.legacyPackages.x86_64-linux; + in + pkgs.writeShellApplication { + name = "qemu-efi"; + + runtimeInputs = [ pkgs.qemu_kvm ]; + + text = '' + qemu-system-x86_64 \ + -smp 2 -m 2048 -machine q35,accel=kvm \ + -bios ${pkgs.OVMF.fd}/FV/OVMF.fd \ + -snapshot \ + -display none \ + -serial stdio "$@" + ''; + }; + }; + + nixosConfigurations = { + patos = nixpkgs.lib.nixosSystem { + system = "x86_64-linux"; + modules = [ + ./base.nix + ]; + }; }; }; - }; } diff --git a/justfile b/justfile new file mode 100644 index 0000000..cd8f0fd --- /dev/null +++ b/justfile @@ -0,0 +1,16 @@ +set shell := ["/usr/bin/env", "bash", "-euo", "pipefail", "-c"] + +[private] +default: + @just --list + +# Update nix flake +update: + nix flake update + +# Build all targets +build: build-image + +# Build PatOS image +build-image: + nix build .#patos_image From c06bf471cc313260bd7aa04cbd9b268dde770a9b Mon Sep 17 00:00:00 2001 From: Daniel Lundin Date: Thu, 12 Sep 2024 22:44:44 +0200 Subject: [PATCH 2/2] Add initial CI job --- .woodpecker/ci.yaml | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 .woodpecker/ci.yaml diff --git a/.woodpecker/ci.yaml b/.woodpecker/ci.yaml new file mode 100644 index 0000000..5fdfe80 --- /dev/null +++ b/.woodpecker/ci.yaml @@ -0,0 +1,33 @@ +when: + - event: pull_request + - event: push + branch: + - ${CI_REPO_DEFAULT_BRANCH} + +steps: + check: + image: alpine + volumes: + - nix:/nix + commands: + # install nix + - | + test -f /nix/installer || wget -O /nix/installer https://github.com/DeterminateSystems/nix-installer/releases/download/v0.18.0/nix-installer-x86_64-linux + chmod +x /nix/installer + rm -f /nix/receipt.json /nix/nix-installer + /nix/installer install linux --init=none --no-confirm + . /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh + + # configure nix + - | + mkdir -p /etc/nix + cat < /etc/nix/nix.conf + sandbox = false + experimental-features = nix-command flakes + EOF + + # build + - nix build .#patos_image + + # check + - nix flake check