2023-10-01 19:14:39 +00:00
|
|
|
-- Test campsite_type_cost
|
|
|
|
set client_min_messages to warning;
|
|
|
|
create extension if not exists pgtap;
|
|
|
|
reset client_min_messages;
|
|
|
|
|
|
|
|
begin;
|
|
|
|
|
2024-02-13 21:12:30 +00:00
|
|
|
select plan(54);
|
2023-10-01 19:14:39 +00:00
|
|
|
|
|
|
|
set search_path to camper, public;
|
|
|
|
|
|
|
|
select has_table('campsite_type_cost');
|
|
|
|
select has_pk('campsite_type_cost');
|
|
|
|
select col_is_pk('campsite_type_cost', array['campsite_type_id', 'season_id']);
|
|
|
|
select table_privs_are('campsite_type_cost', 'guest', array['SELECT']);
|
|
|
|
select table_privs_are('campsite_type_cost', 'employee', array['SELECT']);
|
|
|
|
select table_privs_are('campsite_type_cost', 'admin', array['SELECT', 'INSERT', 'UPDATE', 'DELETE']);
|
|
|
|
select table_privs_are('campsite_type_cost', 'authenticator', array[]::text[]);
|
|
|
|
|
|
|
|
select has_column('campsite_type_cost', 'campsite_type_id');
|
|
|
|
select col_is_fk('campsite_type_cost', 'campsite_type_id');
|
|
|
|
select fk_ok('campsite_type_cost', 'campsite_type_id', 'campsite_type', 'campsite_type_id');
|
|
|
|
select col_type_is('campsite_type_cost', 'campsite_type_id', 'integer');
|
|
|
|
select col_not_null('campsite_type_cost', 'campsite_type_id');
|
|
|
|
select col_hasnt_default('campsite_type_cost', 'campsite_type_id');
|
|
|
|
|
|
|
|
select has_column('campsite_type_cost', 'season_id');
|
|
|
|
select col_is_fk('campsite_type_cost', 'season_id');
|
|
|
|
select fk_ok('campsite_type_cost', 'season_id', 'season', 'season_id');
|
|
|
|
select col_type_is('campsite_type_cost', 'season_id', 'integer');
|
|
|
|
select col_not_null('campsite_type_cost', 'season_id');
|
|
|
|
select col_hasnt_default('campsite_type_cost', 'season_id');
|
|
|
|
|
|
|
|
select has_column('campsite_type_cost', 'cost_per_night');
|
|
|
|
select col_type_is('campsite_type_cost', 'cost_per_night', 'integer');
|
|
|
|
select col_not_null('campsite_type_cost', 'cost_per_night');
|
|
|
|
select col_hasnt_default('campsite_type_cost', 'cost_per_night');
|
|
|
|
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
select has_column('campsite_type_cost', 'cost_per_adult');
|
2024-02-13 21:12:30 +00:00
|
|
|
select col_type_is('campsite_type_cost', 'cost_per_adult', 'nonnegative_integer');
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
select col_not_null('campsite_type_cost', 'cost_per_adult');
|
|
|
|
select col_hasnt_default('campsite_type_cost', 'cost_per_adult');
|
|
|
|
|
|
|
|
select has_column('campsite_type_cost', 'cost_per_teenager');
|
2024-02-13 21:12:30 +00:00
|
|
|
select col_type_is('campsite_type_cost', 'cost_per_teenager', 'nonnegative_integer');
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
select col_not_null('campsite_type_cost', 'cost_per_teenager');
|
|
|
|
select col_hasnt_default('campsite_type_cost', 'cost_per_teenager');
|
|
|
|
|
|
|
|
select has_column('campsite_type_cost', 'cost_per_child');
|
2024-02-13 21:12:30 +00:00
|
|
|
select col_type_is('campsite_type_cost', 'cost_per_child', 'nonnegative_integer');
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
select col_not_null('campsite_type_cost', 'cost_per_child');
|
|
|
|
select col_hasnt_default('campsite_type_cost', 'cost_per_child');
|
|
|
|
|
2023-10-01 19:14:39 +00:00
|
|
|
|
|
|
|
set client_min_messages to warning;
|
|
|
|
truncate campsite_type_cost cascade;
|
|
|
|
truncate season cascade;
|
|
|
|
truncate campsite_type cascade;
|
|
|
|
truncate media cascade;
|
|
|
|
truncate media_content cascade;
|
|
|
|
truncate company_host cascade;
|
|
|
|
truncate company_user cascade;
|
|
|
|
truncate company cascade;
|
|
|
|
truncate auth."user" cascade;
|
|
|
|
reset client_min_messages;
|
|
|
|
|
|
|
|
insert into auth."user" (user_id, email, name, password, cookie, cookie_expires_at)
|
|
|
|
values (1, 'demo@tandem.blog', 'Demo', 'test', '44facbb30d8a419dfd4bfbc44a4b5539d4970148dfc84bed0e', current_timestamp + interval '1 month')
|
|
|
|
, (5, 'admin@tandem.blog', 'Demo', 'test', '12af4c88b528c2ad4222e3740496ecbc58e76e26f087657524', current_timestamp + interval '1 month')
|
|
|
|
;
|
|
|
|
|
2024-02-27 18:45:47 +00:00
|
|
|
insert into company (company_id, business_name, vatin, trade_name, phone, email, web, address, city, province, postal_code, rtc_number, tourist_tax, tourist_tax_max_days, country_code, currency_code, default_lang_tag)
|
|
|
|
values (2, 'Company 2', 'XX123', '', '555-555-555', 'a@a', '', '', '', '', '', '', 60, 7, 'ES', 'EUR', 'ca')
|
|
|
|
, (4, 'Company 4', 'XX234', '', '666-666-666', 'b@b', '', '', '', '', '', '', 60, 7, 'FR', 'USD', 'ca')
|
2023-10-01 19:14:39 +00:00
|
|
|
;
|
|
|
|
|
|
|
|
insert into company_user (company_id, user_id, role)
|
|
|
|
values (2, 1, 'admin')
|
|
|
|
, (4, 5, 'admin')
|
|
|
|
;
|
|
|
|
|
|
|
|
insert into company_host (company_id, host)
|
|
|
|
values (2, 'co2')
|
|
|
|
, (4, 'co4')
|
|
|
|
;
|
|
|
|
|
|
|
|
insert into media_content (media_type, bytes)
|
|
|
|
values ('image/x-xpixmap', 'static char *s[]={"1 1 1 1","a c #ffffff","a"};')
|
|
|
|
;
|
|
|
|
|
|
|
|
insert into media (media_id, company_id, original_filename, content_hash)
|
|
|
|
values (6, 2, 'cover2.xpm', sha256('static char *s[]={"1 1 1 1","a c #ffffff","a"};'))
|
|
|
|
, (8, 4, 'cover4.xpm', sha256('static char *s[]={"1 1 1 1","a c #ffffff","a"};'))
|
|
|
|
;
|
|
|
|
|
Add campsite_type_pet_cost relation to hold price of dogs in campsites
It is a separate relation, instead of having a field in campsite_type,
because not all campsite types allow dogs. I could have added a new
field to campsite_type, but then its values it would be meaningless for
campsites that do not allow dogs, and a nullable field is not a valid
solution because NULL means “unknown”, but we **do** know the price —
none.
A separate relation encodes the same information without ambiguities nor
null values, and, in fact, removed the dogs_allowed field from
campsite_type to prevent erroneous status, such as a campsite type that
allows dogs without having a cost — even if the cost is zero, it has to
be added to the new relation.
2024-02-10 05:18:30 +00:00
|
|
|
insert into campsite_type (campsite_type_id, company_id, name, media_id, max_campers, bookable_nights)
|
|
|
|
values (16, 2, 'Wooden lodge', 6, 7, '[1, 7]')
|
|
|
|
, (18, 4, 'Bungalow', 8, 6, '[2, 6]')
|
2023-10-01 19:14:39 +00:00
|
|
|
;
|
|
|
|
|
|
|
|
insert into season (season_id, company_id, name)
|
|
|
|
values (26, 2, 'Low')
|
|
|
|
, (27, 2, 'Mid')
|
|
|
|
, (28, 4, 'Low')
|
|
|
|
, (29, 4, 'Mid')
|
|
|
|
;
|
|
|
|
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
insert into campsite_type_cost (campsite_type_id, season_id, cost_per_night, cost_per_adult, cost_per_teenager, cost_per_child)
|
|
|
|
values (16, 26, 2, 3, 1, 0)
|
|
|
|
, (18, 28, 4, 5, 6, 7)
|
2023-10-01 19:14:39 +00:00
|
|
|
;
|
|
|
|
|
|
|
|
prepare campsite_season_data as
|
|
|
|
select campsite_type_id, season_id, cost_per_night
|
|
|
|
from campsite_type_cost
|
|
|
|
;
|
|
|
|
|
|
|
|
set role guest;
|
|
|
|
select bag_eq(
|
|
|
|
'campsite_season_data',
|
|
|
|
$$ values (16, 26, 2)
|
|
|
|
, (18, 28, 4)
|
|
|
|
$$,
|
|
|
|
'Everyone should be able to list all campsite type costs across all companies'
|
|
|
|
);
|
|
|
|
reset role;
|
|
|
|
|
|
|
|
select set_cookie('44facbb30d8a419dfd4bfbc44a4b5539d4970148dfc84bed0e/demo@tandem.blog', 'co2');
|
|
|
|
|
|
|
|
select lives_ok(
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
$$ insert into campsite_type_cost(campsite_type_id, season_id, cost_per_night, cost_per_adult, cost_per_teenager, cost_per_child) values (16, 27, 3, 4, 5, 6) $$,
|
2023-10-01 19:14:39 +00:00
|
|
|
'Admin from company 2 should be able to insert a new campsite type season to that company.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select bag_eq(
|
|
|
|
'campsite_season_data',
|
|
|
|
$$ values (16, 26, 2)
|
|
|
|
, (16, 27, 3)
|
|
|
|
, (18, 28, 4)
|
|
|
|
$$,
|
|
|
|
'The new row should have been added'
|
|
|
|
);
|
|
|
|
|
|
|
|
select lives_ok(
|
|
|
|
$$ update campsite_type_cost set cost_per_night = 6 where campsite_type_id = 16 and season_id = 27 $$,
|
|
|
|
'Admin from company 2 should be able to update campsite type season of that company.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select bag_eq(
|
|
|
|
'campsite_season_data',
|
|
|
|
$$ values (16, 26, 2)
|
|
|
|
, (16, 27, 6)
|
|
|
|
, (18, 28, 4)
|
|
|
|
$$,
|
|
|
|
'The row should have been updated.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select lives_ok(
|
|
|
|
$$ delete from campsite_type_cost where campsite_type_id = 16 and season_id = 27 $$,
|
|
|
|
'Admin from company 2 should be able to delete campsite type season from that company.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select bag_eq(
|
|
|
|
'campsite_season_data',
|
|
|
|
$$ values (16, 26, 2)
|
|
|
|
, (18, 28, 4)
|
|
|
|
$$,
|
|
|
|
'The row should have been deleted.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select throws_ok(
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
$$ insert into campsite_type_cost (campsite_type_id, season_id, cost_per_night, cost_per_adult, cost_per_teenager, cost_per_child) values (18, 29, 5, 6, 7, 8) $$,
|
2023-10-01 19:14:39 +00:00
|
|
|
'42501', 'new row violates row-level security policy for table "campsite_type_cost"',
|
|
|
|
'Admin from company 2 should NOT be able to insert new campsite type costs to company 4.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select throws_ok(
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
$$ insert into campsite_type_cost (campsite_type_id, season_id, cost_per_night, cost_per_adult, cost_per_teenager, cost_per_child) values (18, 27, 5, 6, 7, 8) $$,
|
2023-10-01 19:14:39 +00:00
|
|
|
'42501', 'new row violates row-level security policy for table "campsite_type_cost"',
|
|
|
|
'Admin from company 2 should NOT be able to insert new row with a campsite type from company 4.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select throws_ok(
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
$$ insert into campsite_type_cost (campsite_type_id, season_id, cost_per_night, cost_per_adult, cost_per_teenager, cost_per_child) values (16, 29, 5, 6, 7, 8) $$,
|
2023-10-01 19:14:39 +00:00
|
|
|
'42501', 'new row violates row-level security policy for table "campsite_type_cost"',
|
|
|
|
'Admin from company 2 should NOT be able to insert new row with a season from company 4.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select lives_ok(
|
|
|
|
$$ update campsite_type_cost set cost_per_night = 1 where campsite_type_id = 18 $$,
|
|
|
|
'Admin from company 2 should not be able to update campsite types of company 4, but no error if campsite_type_id is not changed.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select lives_ok(
|
|
|
|
$$ update campsite_type_cost set cost_per_night = 1 where season_id = 28 $$,
|
|
|
|
'Admin from company 2 should not be able to update seasons of company 4, but no error if season_id is not changed.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select bag_eq(
|
|
|
|
'campsite_season_data',
|
|
|
|
$$ values (16, 26, 2)
|
|
|
|
, (18, 28, 4)
|
|
|
|
$$,
|
|
|
|
'No row should have been changed.'
|
|
|
|
);
|
|
|
|
|
|
|
|
select throws_ok(
|
|
|
|
$$ update campsite_type_cost set campsite_type_id = 18 where campsite_type_id = 16 $$,
|
|
|
|
'42501', 'new row violates row-level security policy for table "campsite_type_cost"',
|
|
|
|
'Admin from company 2 should NOT be able to move campsite type to one of company 4'
|
|
|
|
);
|
|
|
|
|
|
|
|
select throws_ok(
|
|
|
|
$$ update campsite_type_cost set season_id = 29 where season_id = 26 $$,
|
|
|
|
'42501', 'new row violates row-level security policy for table "campsite_type_cost"',
|
|
|
|
'Admin from company 2 should NOT be able to move season to one of company 4'
|
|
|
|
);
|
|
|
|
|
|
|
|
select lives_ok(
|
|
|
|
$$ delete from campsite_type_cost where campsite_type_id = 18 $$,
|
|
|
|
'Admin from company 2 should NOT be able to delete campsite type from company 4, but not error is thrown'
|
|
|
|
);
|
|
|
|
|
|
|
|
select lives_ok(
|
|
|
|
$$ delete from campsite_type_cost where season_id = 28 $$,
|
|
|
|
'Admin from company 2 should NOT be able to delete season from company 4, but not error is thrown'
|
|
|
|
);
|
|
|
|
|
|
|
|
select bag_eq(
|
|
|
|
'campsite_season_data',
|
|
|
|
$$ values (16, 26, 2)
|
|
|
|
, (18, 28, 4)
|
|
|
|
$$,
|
|
|
|
'No row should have been changed'
|
|
|
|
);
|
|
|
|
|
|
|
|
select throws_ok(
|
Compute and show the “cart” for the booking form
I have to ask number and age ranges of hosts of guests for all campsite
types, not only those that have price options for adults, children, etc.
because i must compute the tourist tax for adults. These numbers will
be used to generate de rows for guests when actually creating the
booking, which is not done already.
To satisfy the campsite types that do have a price per guest, not only
per night, i had to add the prices for each range in the
campsite_type_cost relation. If a campsite type does not have price
per person, then that should be zero; the website then does not display
the price.
The minimal price for any campsite type is one adult for one night,
thus to compute the price i need at least the campsite type, the dates,
and the number of adults, that has a minimum of one. I changed the
order of the form to ask for these values first, so i can compute the
initial price as soon as possible. To help further, i show the
<fieldset>s progressively when visitors select options.
2024-02-04 05:37:25 +00:00
|
|
|
$$ insert into campsite_type_cost (campsite_type_id, season_id, cost_per_night, cost_per_adult, cost_per_teenager, cost_per_child) values (16, 27, -1, 2, 3, 4) $$,
|
2023-10-01 19:14:39 +00:00
|
|
|
'23514', 'new row for relation "campsite_type_cost" violates check constraint "cost_not_negative"',
|
|
|
|
'Should not be able to insert campsite type costs with negative cost per night.'
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
reset role;
|
|
|
|
|
|
|
|
|
|
|
|
select *
|
|
|
|
from finish();
|
|
|
|
|
|
|
|
rollback;
|
|
|
|
|