mirror of https://github.com/artifacthub/hub.git
168 lines
4.3 KiB
SQL
168 lines
4.3 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'
|
|
|
|
-- 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',
|
|
'package1',
|
|
'1.0.0',
|
|
:'repo1ID'
|
|
);
|
|
insert into snapshot (
|
|
package_id,
|
|
version,
|
|
ts,
|
|
changes,
|
|
contains_security_updates,
|
|
prerelease
|
|
) values (
|
|
:'package1ID',
|
|
'1.0.0',
|
|
'2020-06-16 11:20:34+02',
|
|
'[
|
|
{
|
|
"kind": "added",
|
|
"description": "feature 3",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
},
|
|
{
|
|
"kind": "fixed",
|
|
"description": "fix 3",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
}
|
|
]',
|
|
true,
|
|
true
|
|
);
|
|
insert into snapshot (
|
|
package_id,
|
|
version,
|
|
ts,
|
|
changes,
|
|
contains_security_updates,
|
|
prerelease
|
|
) values (
|
|
:'package1ID',
|
|
'0.0.9',
|
|
'2020-06-16 11:20:33+02',
|
|
'[
|
|
{
|
|
"kind": "added",
|
|
"description": "feature 2",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
},
|
|
{
|
|
"kind": "fixed",
|
|
"description": "fix 2",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
}
|
|
]',
|
|
false,
|
|
false
|
|
);
|
|
insert into snapshot (
|
|
package_id,
|
|
version,
|
|
ts,
|
|
changes
|
|
) values (
|
|
:'package1ID',
|
|
'0.0.8',
|
|
'2020-06-16 11:20:32+02',
|
|
'[
|
|
{
|
|
"kind": "added",
|
|
"description": "feature 1",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
},
|
|
{
|
|
"kind": "fixed",
|
|
"description": "fix 1",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
}
|
|
]'
|
|
);
|
|
|
|
-- Run some tests
|
|
select is(
|
|
get_package_changelog('00000000-0000-0000-0000-000000000001')::jsonb,
|
|
'[
|
|
{
|
|
"version": "1.0.0",
|
|
"ts": 1592299234,
|
|
"changes": [
|
|
{
|
|
"kind": "added",
|
|
"description": "feature 3",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
},
|
|
{
|
|
"kind": "fixed",
|
|
"description": "fix 3",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
}
|
|
],
|
|
"contains_security_updates": true,
|
|
"prerelease": true
|
|
},
|
|
{
|
|
"version": "0.0.9",
|
|
"ts": 1592299233,
|
|
"changes": [
|
|
{
|
|
"kind": "added",
|
|
"description": "feature 2",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
},
|
|
{
|
|
"kind": "fixed",
|
|
"description": "fix 2",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
}
|
|
],
|
|
"contains_security_updates": false,
|
|
"prerelease": false
|
|
},
|
|
{
|
|
"version": "0.0.8",
|
|
"ts": 1592299232,
|
|
"changes": [
|
|
{
|
|
"kind": "added",
|
|
"description": "feature 1",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
},
|
|
{
|
|
"kind": "fixed",
|
|
"description": "fix 1",
|
|
"links": [{"name": "github issue", "url": "https://issue.url"}]
|
|
}
|
|
]
|
|
}
|
|
]'::jsonb,
|
|
'Package changelog should be returned'
|
|
);
|
|
select is(
|
|
get_package_changelog('00000000-0000-0000-0000-000000000002')::jsonb,
|
|
'[]'::jsonb,
|
|
'Empty changelog should be returned for inexistent package'
|
|
);
|
|
|
|
-- Finish tests and rollback transaction
|
|
select * from finish();
|
|
rollback;
|