aboutsummaryrefslogtreecommitdiff
path: root/default.nix
diff options
context:
space:
mode:
authorEuAndreh <eu@euandre.org>2019-06-04 15:02:04 -0300
committerEuAndreh <eu@euandre.org>2019-06-04 15:02:29 -0300
commitc12079c3b61a5f795350a29c71322d932162e260 (patch)
treefb9a18b26e91602285eabc30d30da1c5c25a0619 /default.nix
parentTODOs.org (diff)
downloadserver-c12079c3b61a5f795350a29c71322d932162e260.tar.gz
server-c12079c3b61a5f795350a29c71322d932162e260.tar.xz
Add utils.nix and remove common derivations from default.nix
Diffstat (limited to 'default.nix')
-rw-r--r--default.nix103
1 files changed, 24 insertions, 79 deletions
diff --git a/default.nix b/default.nix
index 9ed4049..4ea1ec0 100644
--- a/default.nix
+++ b/default.nix
@@ -1,51 +1,14 @@
-let
- pkgsUnstable = import <nixpkgs> { };
- pkgsPinned = import (pkgsUnstable.fetchzip {
- url = "https://github.com/NixOS/nixpkgs/archive/18.03.zip";
- sha256 = "0hk4y2vkgm1qadpsm4b0q1vxq889jhxzjx3ragybrlwwg54mzp4f";
- }) { };
- pkgs = pkgsUnstable;
-
- nixfmt = import (builtins.fetchTarball
- "https://github.com/serokell/nixfmt/archive/master.tar.gz") { };
-
- baseTask = pkgs.stdenv.mkDerivation {
- name = "vps-task";
+let pkgs = import <nixpkgs> { };
+in rec {
+ utils = import ./utils.nix {
+ pkgs = pkgs;
src = pkgs.nix-gitignore.gitignoreSource [ ] ./.;
- phases = "unpackPhase buildPhase";
- buildInputs = [ ];
- buildPhase = ''
- echo "ERROR: base task buildPhase not overriden."
- exit 1
- '';
+ baseName = "dotfiles";
};
-in with pkgs;
-with pkgs.stdenv; rec {
subtasks = rec {
- shellCheck = baseTask.overrideAttrs (baseAttrs: {
- name = "${baseAttrs.name}-shellcheck";
- buildInputs = baseAttrs.buildInputs ++ [ shellcheck ];
- buildPhase = ''
- find . -type f -name '*.sh' | xargs shellcheck
- touch $out
- '';
- });
- fixme = baseTask.overrideAttrs (baseAttrs: {
- name = "${baseAttrs.name}-fixme";
- buildInputs = baseAttrs.buildInputs ++ [ ag ];
- buildPhase = ''
- ag FIXME --ignore default.nix || {
- touch $out
- exit 0
- }
- echo "^^^^^^^^^^^^^^^^^"
- echo " Found dangling FIXME markers on the project xp"
- exit 1
- '';
- });
- formatTerraform = baseTask.overrideAttrs (baseAttrs: {
+ formatTerraform = utils.baseTask.overrideAttrs (baseAttrs: {
name = "${baseAttrs.name}-format-terraform";
- buildInputs = baseAttrs.buildInputs ++ [ terraform ];
+ buildInputs = baseAttrs.buildInputs ++ [ pkgs.terraform ];
buildPhase = ''
terraform fmt -check=true -diff=true || {
echo "Terraform files are unformatted. To fix it, run:"
@@ -55,9 +18,9 @@ with pkgs.stdenv; rec {
touch $out
'';
});
- dockerComposeLint = baseTask.overrideAttrs (baseAttrs: {
+ dockerComposeLint = utils.baseTask.overrideAttrs (baseAttrs: {
name = "${baseAttrs.name}-docker-compose-lint";
- buildInputs = baseAttrs.buildInputs ++ [ docker-compose ];
+ buildInputs = baseAttrs.buildInputs ++ [ pkgs.docker-compose ];
buildPhase = ''
source .envrc
docker-compose config &> /dev/null || {
@@ -67,41 +30,23 @@ with pkgs.stdenv; rec {
touch $out
'';
});
- formatNix = baseTask.overrideAttrs (baseAttrs: {
- name = "${baseAttrs.name}-nixfmt";
- buildInputs = baseAttrs.buildInputs ++ [ nixfmt ];
- buildPhase = ''
- diff <(nixfmt < default.nix) default.nix || {
- echo "The default.nix is unformatted. To fix it, run:"
- echo " nixfmt default.nix"
- exit 1
- }
- touch $out
- '';
- });
};
- test = baseTask.overrideAttrs (baseAttrs: rec {
- name = "${baseAttrs.name}-test";
- buildInputs = [
- subtasks.shellCheck
- subtasks.fixme
- subtasks.formatTerraform
- subtasks.dockerComposeLint
- subtasks.formatNix
- ];
- buildPhase = ''
- echo "Ran tests for:"
- for d in ${builtins.toString buildInputs}; do
- echo " $d"
- done
- echo "All tests passed!"
- touch $out
- '';
- });
+ test = utils.test [
+ (utils.shellcheck null)
+ (utils.fixme null)
+ utils.formatNix
+ subtasks.formatTerraform
+ subtasks.dockerComposeLint
+ ];
# Used in .build.yml to run Bash scripts
- shell = mkShell rec {
+ shell = pkgs.mkShell rec {
name = "vps-shell";
- buildInputs =
- [ gitMinimal git-crypt gettext terraform-providers.digitalocean terraform ];
+ buildInputs = with pkgs; [
+ gitMinimal
+ git-crypt
+ gettext
+ terraform-providers.digitalocean
+ terraform
+ ];
};
}