|
1 | 1 | { self, pkgs }:
|
2 | 2 | let
|
| 3 | + pname = "timescaledb"; |
3 | 4 | inherit (pkgs) lib;
|
4 | 5 | installedExtension =
|
5 |
| - postgresMajorVersion: |
6 |
| - self.packages.${pkgs.system}."psql_${postgresMajorVersion}/exts/timescaledb-all"; |
| 6 | + postgresMajorVersion: self.packages.${pkgs.system}."psql_${postgresMajorVersion}/exts/${pname}-all"; |
7 | 7 | versions = (installedExtension "15").versions;
|
8 |
| - firstVersion = lib.head versions; |
9 | 8 | postgresqlWithExtension =
|
10 | 9 | postgresql:
|
11 | 10 | let
|
12 | 11 | majorVersion = lib.versions.major postgresql.version;
|
13 | 12 | pkg = pkgs.buildEnv {
|
14 |
| - name = "postgresql-${majorVersion}-timescaledb"; |
| 13 | + name = "postgresql-${majorVersion}-${pname}"; |
15 | 14 | paths = [
|
16 | 15 | postgresql
|
17 | 16 | postgresql.lib
|
|
36 | 35 | };
|
37 | 36 | in
|
38 | 37 | pkg;
|
| 38 | + psql_15 = postgresqlWithExtension self.packages.${pkgs.system}.postgresql_15; |
39 | 39 | in
|
40 | 40 | self.inputs.nixpkgs.lib.nixos.runTest {
|
41 | 41 | name = "timescaledb";
|
42 | 42 | hostPkgs = pkgs;
|
43 | 43 | nodes.server =
|
44 | 44 | { ... }:
|
45 | 45 | {
|
46 |
| - virtualisation = { |
47 |
| - forwardPorts = [ |
48 |
| - { |
49 |
| - from = "host"; |
50 |
| - host.port = 13022; |
51 |
| - guest.port = 22; |
52 |
| - } |
53 |
| - ]; |
54 |
| - }; |
55 |
| - services.openssh = { |
56 |
| - enable = true; |
57 |
| - }; |
58 |
| - users.users.root.openssh.authorizedKeys.keys = [ |
59 |
| - "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIArkmq6Th79Z4klW6Urgi4phN8yq769/l/10jlE00tU9" |
60 |
| - ]; |
61 |
| - |
62 | 46 | services.postgresql = {
|
63 | 47 | enable = true;
|
64 |
| - package = postgresqlWithExtension self.packages.${pkgs.system}.postgresql_15; |
| 48 | + package = (postgresqlWithExtension psql_15); |
65 | 49 | settings = {
|
66 | 50 | shared_preload_libraries = "timescaledb";
|
67 | 51 | };
|
68 | 52 | };
|
69 |
| - |
70 |
| - specialisation.postgresql15.configuration = { |
71 |
| - services.postgresql = { |
72 |
| - package = lib.mkForce (postgresqlWithExtension self.packages.${pkgs.system}.postgresql_15); |
73 |
| - }; |
74 |
| - }; |
75 | 53 | };
|
76 | 54 | testScript =
|
77 | 55 | { ... }:
|
78 | 56 | ''
|
79 |
| - def run_sql(query): |
80 |
| - return server.succeed(f"""sudo -u postgres psql -t -A -F\",\" -c \"{query}\" """).strip() |
81 |
| -
|
82 |
| - def check_upgrade_path(): |
83 |
| - with subtest("Check timescaledb upgrade path"): |
84 |
| - server.succeed("sudo -u postgres psql -c 'DROP EXTENSION IF EXISTS timescaledb;'") |
85 |
| - run_sql(r"""CREATE EXTENSION timescaledb WITH VERSION \"${firstVersion}\";""") |
86 |
| - installed_version = run_sql(r"""SELECT extversion FROM pg_extension WHERE extname = 'timescaledb';""") |
87 |
| - assert installed_version == "${firstVersion}", f"Expected timescaledb version ${firstVersion}, but found {installed_version}" |
88 |
| - for version in [${lib.concatStringsSep ", " (map (s: ''"${s}"'') versions)}][1:]: |
89 |
| - run_sql(f"""ALTER EXTENSION timescaledb UPDATE TO '{version}';""") |
90 |
| - installed_version = run_sql(r"""SELECT extversion FROM pg_extension WHERE extname = 'timescaledb';""") |
91 |
| - assert installed_version == version, f"Expected timescaledb version {version}, but found {installed_version}" |
| 57 | + ${builtins.readFile ./lib.py} |
92 | 58 |
|
93 | 59 | start_all()
|
94 | 60 |
|
95 | 61 | server.wait_for_unit("multi-user.target")
|
96 | 62 | server.wait_for_unit("postgresql.service")
|
97 | 63 |
|
98 |
| - check_upgrade_path() |
| 64 | + versions = { |
| 65 | + "15": [${lib.concatStringsSep ", " (map (s: ''"${s}"'') versions)}], |
| 66 | + } |
| 67 | + extension_name = "${pname}" |
| 68 | + support_upgrade = True |
| 69 | +
|
| 70 | + test = PostgresExtensionTest(server, extension_name, versions, support_upgrade) |
| 71 | +
|
| 72 | + with subtest("Check upgrade path with postgresql 15"): |
| 73 | + test.check_upgrade_path("15") |
| 74 | +
|
| 75 | + with subtest("Test switch_${pname}_version"): |
| 76 | + test.check_switch_extension_with_background_worker(Path("${psql_15}/lib/${pname}.so"), "15") |
99 | 77 | '';
|
100 | 78 | }
|
0 commit comments