Skip to content

Commit 1f5bfb4

Browse files
committed
nix: bring back net-with-pg-xx commands
1 parent 7bc3a55 commit 1f5bfb4

File tree

10 files changed

+73
-27
lines changed

10 files changed

+73
-27
lines changed

.github/workflows/main.yml

+3-9
Original file line numberDiff line numberDiff line change
@@ -17,9 +17,7 @@ jobs:
1717
nix_path: nixpkgs=channel:nixos-unstable
1818

1919
- name: Run tests
20-
run: |
21-
nix-shell --run "nxpg-${{ matrix.pg-version }} nxpg-build"
22-
nix-shell --run "net-with-nginx nxpg-${{ matrix.pg-version }} nxpg-tmp nxpg-test"
20+
run: nix-shell --run "net-with-nginx net-with-pg-${{ matrix.pg-version }} python -m pytest -vv"
2321

2422
#- name: Check C files are formatted
2523
#run: nix-shell --run "net-check-format"
@@ -37,9 +35,7 @@ jobs:
3735
with:
3836
nix_path: nixpkgs=channel:nixos-unstable
3937
- name: Run tests
40-
run: |
41-
nix-shell --run "nxpg-${{ matrix.pg-version }} nxpg-build"
42-
nix-shell --run "net-with-nginx nxpg-${{ matrix.pg-version }} nxpg-tmp nxpg-test"
38+
run: nix-shell --run "net-with-nginx net-with-pg-${{ matrix.pg-version }} python -m pytest -vv"
4339

4440
coverage:
4541

@@ -58,9 +54,7 @@ jobs:
5854
nix_path: nixpkgs=channel:nixos-unstable
5955

6056
- name: Run coverage
61-
run: |
62-
nix-shell --run "nxpg-${{ matrix.pg-version }} nxpg-build-cov"
63-
nix-shell --run "net-with-nginx nxpg-${{ matrix.pg-version }} nxpg-tmp nxpg-coverage"
57+
run: nix-shell --run "net-with-nginx net-with-pg-${{ matrix.pg-version }} nxpg-coverage"
6458

6559
- name: Send coverage to Coveralls
6660
uses: coverallsapp/[email protected]

docs/contributing.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -14,10 +14,10 @@ For testing locally, execute:
1414
$ nix-shell
1515

1616
# test on pg 12
17-
$ nxpg-12 nxpg-build && net-with-nginx nxpg-12 nxpg-tmp nxpg-test
17+
$ net-with-pg-12 python -m pytest -vv
1818

1919
# test on pg 13
20-
$ nxpg-13 nxpg-build && net-with-nginx nxpg-13 nxpg-tmp nxpg-test
20+
$ net-with-pg-13 python -m pytest -vv
2121
```
2222

2323
### Debugging

nix/nxpg.nix

+21-15
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,4 @@
1-
{ stdenv, lib, makeWrapper, fetchurl, writeShellScriptBin, findutils, entr, callPackage, lcov
2-
, pidFileName, gnused, python3
3-
, postgresql_16, postgresql_15, postgresql_14, postgresql_13, postgresql_12
4-
} :
1+
{ stdenv, lib, makeWrapper, fetchurl, writeShellScriptBin, findutils, entr, callPackage, lcov, pidFileName, gnused, python3 } :
52
let
63
prefix = "nxpg";
74
ourPg = callPackage ./postgresql {
@@ -13,11 +10,11 @@ let
1310
};
1411
supportedPgs = [
1512
ourPg.postgresql_17
16-
postgresql_16
17-
postgresql_15
18-
postgresql_14
19-
postgresql_13
20-
postgresql_12
13+
ourPg.postgresql_16
14+
ourPg.postgresql_15
15+
ourPg.postgresql_14
16+
ourPg.postgresql_13
17+
ourPg.postgresql_12
2118
];
2219
build =
2320
writeShellScriptBin "${prefix}-build" ''
@@ -108,21 +105,29 @@ let
108105
allPgPaths = map (pg:
109106
let
110107
ver = builtins.head (builtins.splitVersion pg.version);
111-
patchedPg = pg.overrideAttrs(oldAttrs: {
112-
patches = oldAttrs.patches ++ [
113-
./postgresql/patches/${ver}-add-extension_control_path-for.patch
114-
];
115-
});
116108
script = ''
117109
set -euo pipefail
118110
119-
export PATH=${patchedPg}/bin:"$PATH"
111+
export PATH=${pg}/bin:"$PATH"
120112
121113
"$@"
122114
'';
123115
in
124116
writeShellScriptBin "${prefix}-${ver}" script
125117
) supportedPgs;
118+
119+
netWith = map (pg:
120+
let
121+
ver = builtins.head (builtins.splitVersion pg.version);
122+
script = ''
123+
set -euo pipefail
124+
export PATH=${pg}/bin:"$PATH"
125+
${buildCov}/bin/${prefix}-build-cov
126+
${tmpDb}/bin/${prefix}-tmp "$@"
127+
'';
128+
in
129+
writeShellScriptBin "net-with-pg-${ver}" script
130+
) supportedPgs;
126131
in
127132
[
128133
build
@@ -132,4 +137,5 @@ in
132137
watch
133138
tmpDb
134139
allPgPaths
140+
netWith
135141
]

nix/postgresql/12.nix

+4
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
import ./generic.nix {
2+
version = "12.19";
3+
hash = "sha256-YX495Swi6CL09X0B1bIkBQPhmKnsyvWYqFEQm9GOb7s=";
4+
}

nix/postgresql/13.nix

+4
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
import ./generic.nix {
2+
version = "13.15";
3+
hash = "sha256-Qu3UFURtM7jCQr520a0FdTGyJksuhpOTObcHXG5OySU=";
4+
}

nix/postgresql/14.nix

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
import ./generic.nix {
2+
version = "14.12";
3+
hash = "sha256-YRjQj53cwb2Dzyt8x007WDvc7C835iRaisADuPqoCSM=";
4+
muslPatches = {
5+
disable-test-collate-icu-utf8 = {
6+
url = "https://git.alpinelinux.org/aports/plain/main/postgresql14/disable-test-collate.icu.utf8.patch?id=56999e6d0265ceff5c5239f85fdd33e146f06cb7";
7+
hash = "sha256-jXe23AxnFjEl+TZQm4R7rStk2Leo08ctxMNmu1xr5zM=";
8+
};
9+
};
10+
}

nix/postgresql/15.nix

+4
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
import ./generic.nix {
2+
version = "15.7";
3+
hash = "sha256-pG/klIWrY4Xjnau7tlT10wSSBvds1pXiJCaHKVIJmPc=";
4+
}

nix/postgresql/16.nix

+4
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
import ./generic.nix {
2+
version = "16.3";
3+
hash = "sha256-Mxlj1dPcTK9CFqBJ+kC2bWvLjHMGFYWUEblRh2TmBYU=";
4+
}

nix/postgresql/default.nix

+6
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,13 @@ let
88
# for a bit longer to still update up to this commit to at least get the latest minor
99
# version. In other words: Do not remove the second-to-last minor version from nixpkgs,
1010
# yet. Update first.
11+
1112
versions = {
13+
postgresql_12 = ./12.nix;
14+
postgresql_13 = ./13.nix;
15+
postgresql_14 = ./14.nix;
16+
postgresql_15 = ./15.nix;
17+
postgresql_16 = ./16.nix;
1218
postgresql_17 = ./17.nix;
1319
};
1420

nix/postgresql/generic.nix

+15-1
Original file line numberDiff line numberDiff line change
@@ -117,6 +117,7 @@ let
117117
./patches/specify_pkglibdir_at_runtime.patch
118118
./patches/paths-with-postgresql-suffix.patch
119119

120+
120121
(substituteAll {
121122
src = ./patches/locale-binary-path.patch;
122123
locale = "${if stdenv.isDarwin then darwin.adv_cmds else lib.getBin stdenv.cc.libc}/bin/locale";
@@ -127,7 +128,20 @@ let
127128
map fetchurl (lib.attrValues muslPatches)
128129
) ++ lib.optionals stdenv'.isLinux [
129130
(if atLeast "13" then ./patches/socketdir-in-run-13+.patch else ./patches/socketdir-in-run.patch)
130-
];
131+
] ++ (if atLeast "17"
132+
then [./patches/17-add-extension_control_path-for.patch]
133+
else if atLeast "16"
134+
then [./patches/16-add-extension_control_path-for.patch]
135+
else if atLeast "15"
136+
then [./patches/15-add-extension_control_path-for.patch]
137+
else if atLeast "14"
138+
then [./patches/14-add-extension_control_path-for.patch]
139+
else if atLeast "13"
140+
then [./patches/13-add-extension_control_path-for.patch]
141+
else if atLeast "12"
142+
then [./patches/12-add-extension_control_path-for.patch]
143+
else []
144+
);
131145

132146
installTargets = [ "install-world" ];
133147

0 commit comments

Comments
 (0)