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

81 lines
2.2 KiB
SQL

-- Start transaction and plan tests
begin;
select plan(6);
-- Declare some variables
\set user1ID '00000000-0000-0000-0000-000000000001'
\set repo1ID '00000000-0000-0000-0000-000000000001'
\set package1ID '00000000-0000-0000-0000-000000000001'
-- Seed some data
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',
'Package 1',
'1.0.0',
:'repo1ID'
);
-- Run some tests
select is_empty(
$$
select * from user_starred_package
where user_id = '00000000-0000-0000-0000-000000000001'
and package_id = '00000000-0000-0000-0000-000000000001'
$$,
'No starred packages yet'
);
select results_eq(
$$
select stars from package
where package_id = '00000000-0000-0000-0000-000000000001'
$$,
'values (0)',
'Package1 stars should be 0 as it has never been starred'
);
select toggle_star(:'user1ID', :'package1ID');
select isnt_empty(
$$
select * from user_starred_package
where user_id = '00000000-0000-0000-0000-000000000001'
and package_id = '00000000-0000-0000-0000-000000000001'
$$,
'Package1 has been starred by user1'
);
select results_eq(
$$
select stars from package
where package_id = '00000000-0000-0000-0000-000000000001'
$$,
'values (1)',
'Package1 stars should be 1 as it has just been starred'
);
select toggle_star(:'user1ID', :'package1ID');
select is_empty(
$$
select * from user_starred_package
where user_id = '00000000-0000-0000-0000-000000000001'
and package_id = '00000000-0000-0000-0000-000000000001'
$$,
'User1 star for package1 should have been removed'
);
select results_eq(
$$
select stars from package
where package_id = '00000000-0000-0000-0000-000000000001'
$$,
'values (0)',
'Package1 stars should be 0 as its only star was just removed'
);
-- Finish tests and rollback transaction
select * from finish();
rollback;