hub/database/tests/functions/packages/get_packages_stats.sql

138 lines
2.5 KiB
SQL

-- Start transaction and plan tests
begin;
select plan(2);
-- Declare some variables
\set user1ID '00000000-0000-0000-0000-000000000001'
\set repo1ID '00000000-0000-0000-0000-000000000001'
\set package1ID '00000000-0000-0000-0000-000000000001'
\set package2ID '00000000-0000-0000-0000-000000000002'
-- No packages at this point
select is(
get_packages_stats()::jsonb,
'{
"packages": 0,
"releases": 0
}'::jsonb,
'Empty stats are returned as a json object'
);
-- Seed some packages
insert into "user" (user_id, alias, email)
values (:'user1ID', 'user1', 'user1@email.com');
insert into repository (repository_id, name, display_name, url, repository_kind_id, user_id)
values (:'repo1ID', 'repo1', 'Repo 1', 'https://repo1.com', 0, :'user1ID');
insert into package (
package_id,
name,
latest_version,
repository_id
) values (
:'package1ID',
'package1',
'1.0.0',
:'repo1ID'
);
insert into snapshot (
package_id,
version,
display_name,
description,
home_url,
app_version,
digest,
readme
) values (
:'package1ID',
'1.0.0',
'Package 1',
'description',
'home_url',
'12.1.0',
'digest-package1-1.0.0',
'readme'
);
insert into snapshot (
package_id,
version,
display_name,
description,
home_url,
app_version,
digest,
readme
) values (
:'package1ID',
'0.0.9',
'Package 1',
'description',
'home_url',
'12.0.0',
'digest-package1-0.0.9',
'readme'
);
insert into package (
package_id,
name,
latest_version,
repository_id
) values (
:'package2ID',
'package2',
'1.0.0',
:'repo1ID'
);
insert into snapshot (
package_id,
version,
display_name,
description,
home_url,
app_version,
digest,
readme
) values (
:'package2ID',
'1.0.0',
'Package 2',
'description',
'home_url',
'12.1.0',
'digest-package2-1.0.0',
'readme'
);
insert into snapshot (
package_id,
version,
display_name,
description,
home_url,
app_version,
digest,
readme
) values (
:'package2ID',
'0.0.9',
'Package 2',
'description',
'home_url',
'12.0.0',
'digest-package2-0.0.9',
'readme'
);
-- Some packages have just been seeded
select is(
get_packages_stats()::jsonb,
'{
"packages": 2,
"releases": 4
}'::jsonb,
'Stats are returned as a json object'
);
-- Finish tests and rollback transaction
select * from finish();
rollback;