2024-06-11 11:37:01 +01:00
|
|
|
{ name, pkgs, testBase, system, ... }:
|
2024-02-12 15:54:53 +00:00
|
|
|
|
2024-06-11 11:37:01 +01:00
|
|
|
with import ../../lib/testing-python.nix { inherit system pkgs; };
|
|
|
|
runTest ({ config, lib, ... }: let
|
2024-06-10 12:52:47 +01:00
|
|
|
accessKey = "BKIKJAA5BMMU2RHO6IBB";
|
|
|
|
secretKey = "V7f1CwQqAcwo80UEIJEjc5gVQUSSx5ohQ9GSrr12";
|
2024-02-12 15:54:53 +00:00
|
|
|
|
|
|
|
rootCredentialsFile = pkgs.writeText "minio-credentials-full" ''
|
|
|
|
MINIO_ROOT_USER=${accessKey}
|
|
|
|
MINIO_ROOT_PASSWORD=${secretKey}
|
|
|
|
'';
|
|
|
|
in {
|
2024-06-11 11:37:01 +01:00
|
|
|
inherit name;
|
2024-02-12 15:54:53 +00:00
|
|
|
meta = with pkgs.lib.maintainers; {
|
2024-06-10 12:52:47 +01:00
|
|
|
maintainers = [ onny ma27 ];
|
2024-02-12 15:54:53 +00:00
|
|
|
};
|
|
|
|
|
2024-06-11 11:37:01 +01:00
|
|
|
imports = [ testBase ];
|
2024-02-12 15:54:53 +00:00
|
|
|
|
2024-06-11 11:37:01 +01:00
|
|
|
nodes = {
|
2024-02-12 15:54:53 +00:00
|
|
|
nextcloud = { config, pkgs, ... }: {
|
2024-06-11 11:37:01 +01:00
|
|
|
networking.firewall.allowedTCPPorts = [ 9000 ];
|
2024-06-10 12:52:47 +01:00
|
|
|
environment.systemPackages = [ pkgs.minio-client ];
|
2024-02-12 15:54:53 +00:00
|
|
|
|
2024-06-11 11:37:01 +01:00
|
|
|
services.nextcloud.config.objectstore.s3 = {
|
2024-02-12 15:54:53 +00:00
|
|
|
enable = true;
|
2024-06-11 11:37:01 +01:00
|
|
|
bucket = "nextcloud";
|
|
|
|
autocreate = true;
|
|
|
|
key = accessKey;
|
|
|
|
secretFile = "${pkgs.writeText "secretKey" secretKey}";
|
|
|
|
hostname = "nextcloud";
|
|
|
|
useSsl = false;
|
|
|
|
port = 9000;
|
|
|
|
usePathStyle = true;
|
|
|
|
region = "us-east-1";
|
2024-02-12 15:54:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
services.minio = {
|
|
|
|
enable = true;
|
|
|
|
listenAddress = "0.0.0.0:9000";
|
|
|
|
consoleAddress = "0.0.0.0:9001";
|
|
|
|
inherit rootCredentialsFile;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-06-11 11:37:01 +01:00
|
|
|
test-helpers.init = ''
|
2024-02-12 15:54:53 +00:00
|
|
|
nextcloud.wait_for_open_port(9000)
|
|
|
|
'';
|
2024-06-11 11:37:01 +01:00
|
|
|
|
|
|
|
test-helpers.extraTests = { nodes, ... }: ''
|
|
|
|
with subtest("File is not on the filesystem"):
|
|
|
|
nextcloud.succeed("test ! -e ${nodes.nextcloud.services.nextcloud.home}/data/root/files/test-shared-file")
|
|
|
|
|
|
|
|
with subtest("Check if file is in S3"):
|
|
|
|
nextcloud.succeed(
|
|
|
|
"mc config host add minio http://localhost:9000 ${accessKey} ${secretKey} --api s3v4"
|
|
|
|
)
|
|
|
|
files = nextcloud.succeed('mc ls minio/nextcloud|sort').strip().split('\n')
|
|
|
|
|
|
|
|
# Cannot assert an exact number here, nc27 writes more stuff initially into S3.
|
|
|
|
# For now let's assume it's always the most recently added file.
|
|
|
|
assert len(files) > 0, f"""
|
|
|
|
Expected to have at least one object in minio/nextcloud. But `mc ls` gave output:
|
|
|
|
|
|
|
|
'{files}'
|
|
|
|
"""
|
|
|
|
|
|
|
|
import re
|
|
|
|
ptrn = re.compile("^\[[A-Z0-9 :-]+\] +(?P<details>[A-Za-z0-9 :]+)$")
|
|
|
|
match = ptrn.match(files[-1].strip())
|
|
|
|
assert match, "Cannot match mc client output!"
|
|
|
|
size, type_, file = tuple(match.group('details').split(' '))
|
|
|
|
|
|
|
|
assert size == "3B", f"""
|
|
|
|
Expected size of uploaded file to be 3 bytes, got {size}
|
|
|
|
"""
|
|
|
|
|
|
|
|
assert type_ == 'STANDARD', f"""
|
|
|
|
Expected type of bucket entry to be a file, i.e. 'STANDARD'. Got {type_}
|
|
|
|
"""
|
|
|
|
|
|
|
|
assert file.startswith('urn:oid'), """
|
|
|
|
Expected filename to start with 'urn:oid', instead got '{file}.
|
|
|
|
"""
|
|
|
|
|
|
|
|
with subtest("Test download from S3"):
|
|
|
|
client.succeed(
|
|
|
|
"env AWS_ACCESS_KEY_ID=${accessKey} AWS_SECRET_ACCESS_KEY=${secretKey} "
|
|
|
|
+ f"${lib.getExe pkgs.awscli2} s3 cp s3://nextcloud/{file} test --endpoint-url http://nextcloud:9000 "
|
|
|
|
+ "--region us-east-1"
|
|
|
|
)
|
|
|
|
|
|
|
|
client.succeed("test hi = $(cat test)")
|
|
|
|
'';
|
|
|
|
})
|