2022-09-09 10:40:05 +02:00
|
|
|
|
--liquibase formatted sql
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- ============================================================================
|
2022-09-13 13:27:52 +02:00
|
|
|
|
--changeset hs-office-partner-TEST-DATA-GENERATOR:1 endDelimiter:--//
|
2022-09-09 10:40:05 +02:00
|
|
|
|
-- ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
Creates a single partner test record.
|
|
|
|
|
*/
|
2024-01-23 15:11:23 +01:00
|
|
|
|
create or replace procedure createHsOfficePartnerTestData(
|
2024-03-28 12:15:13 +01:00
|
|
|
|
mandantTradeName varchar,
|
|
|
|
|
newPartnerNumber numeric(5),
|
2024-02-01 14:48:15 +01:00
|
|
|
|
partnerPersonName varchar,
|
2024-05-06 09:22:21 +02:00
|
|
|
|
contactCaption varchar )
|
2022-09-09 10:40:05 +02:00
|
|
|
|
language plpgsql as $$
|
|
|
|
|
declare
|
2022-10-20 20:11:31 +02:00
|
|
|
|
idName varchar;
|
2024-02-01 14:48:15 +01:00
|
|
|
|
mandantPerson hs_office_person;
|
2024-03-28 12:15:13 +01:00
|
|
|
|
partnerRel hs_office_relation;
|
2022-10-20 20:11:31 +02:00
|
|
|
|
relatedPerson hs_office_person;
|
|
|
|
|
relatedDetailsUuid uuid;
|
2022-09-09 10:40:05 +02:00
|
|
|
|
begin
|
2024-05-06 09:22:21 +02:00
|
|
|
|
idName := cleanIdentifier( partnerPersonName|| '-' || contactCaption);
|
2022-09-09 10:40:05 +02:00
|
|
|
|
|
2022-10-14 12:37:59 +02:00
|
|
|
|
select p.* from hs_office_person p
|
2024-02-01 14:48:15 +01:00
|
|
|
|
where p.tradeName = mandantTradeName
|
|
|
|
|
into mandantPerson;
|
|
|
|
|
if mandantPerson is null then
|
|
|
|
|
raise exception 'mandant "%" not found', mandantTradeName;
|
|
|
|
|
end if;
|
|
|
|
|
|
|
|
|
|
select p.* from hs_office_person p
|
|
|
|
|
where p.tradeName = partnerPersonName or p.familyName = partnerPersonName
|
2022-10-14 12:37:59 +02:00
|
|
|
|
into relatedPerson;
|
|
|
|
|
|
2024-03-13 15:01:24 +01:00
|
|
|
|
select r.* from hs_office_relation r
|
|
|
|
|
where r.type = 'PARTNER'
|
|
|
|
|
and r.anchoruuid = mandantPerson.uuid and r.holderuuid = relatedPerson.uuid
|
|
|
|
|
into partnerRel;
|
|
|
|
|
if partnerRel is null then
|
|
|
|
|
raise exception 'partnerRel "%"-"%" not found', mandantPerson.tradename, partnerPersonName;
|
2024-02-01 14:48:15 +01:00
|
|
|
|
end if;
|
|
|
|
|
|
2022-09-09 10:40:05 +02:00
|
|
|
|
raise notice 'creating test partner: %', idName;
|
2024-03-13 15:01:24 +01:00
|
|
|
|
raise notice '- using partnerRel (%): %', partnerRel.uuid, partnerRel;
|
2022-09-09 17:43:43 +02:00
|
|
|
|
raise notice '- using person (%): %', relatedPerson.uuid, relatedPerson;
|
2022-09-09 10:40:05 +02:00
|
|
|
|
|
2024-01-24 15:18:44 +01:00
|
|
|
|
if relatedPerson.persontype = 'NP' then
|
2022-10-20 20:11:31 +02:00
|
|
|
|
insert
|
2024-01-24 15:18:44 +01:00
|
|
|
|
into hs_office_partner_details (uuid, birthName, birthday, birthPlace)
|
|
|
|
|
values (uuid_generate_v4(), 'Meyer', '1987-10-31', 'Hamburg')
|
2022-10-20 20:11:31 +02:00
|
|
|
|
returning uuid into relatedDetailsUuid;
|
|
|
|
|
else
|
|
|
|
|
insert
|
|
|
|
|
into hs_office_partner_details (uuid, registrationOffice, registrationNumber)
|
2024-02-01 14:48:15 +01:00
|
|
|
|
values (uuid_generate_v4(), 'Hamburg', 'RegNo123456789')
|
2022-10-20 20:11:31 +02:00
|
|
|
|
returning uuid into relatedDetailsUuid;
|
|
|
|
|
end if;
|
2022-09-09 10:40:05 +02:00
|
|
|
|
|
2022-10-20 20:11:31 +02:00
|
|
|
|
insert
|
2024-03-28 12:15:13 +01:00
|
|
|
|
into hs_office_partner (uuid, partnerNumber, partnerRelUuid, detailsUuid)
|
|
|
|
|
values (uuid_generate_v4(), newPartnerNumber, partnerRel.uuid, relatedDetailsUuid);
|
2022-09-09 10:40:05 +02:00
|
|
|
|
end; $$;
|
|
|
|
|
--//
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- ============================================================================
|
2022-09-13 13:27:52 +02:00
|
|
|
|
--changeset hs-office-partner-TEST-DATA-GENERATION:1 –context=dev,tc endDelimiter:--//
|
2022-09-09 10:40:05 +02:00
|
|
|
|
-- ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
do language plpgsql $$
|
|
|
|
|
begin
|
2024-08-29 17:00:19 +02:00
|
|
|
|
call defineContext('creating partner test-data ', null, 'superuser-alex@hostsharing.net', 'global#global:ADMIN');
|
|
|
|
|
|
2024-02-01 14:48:15 +01:00
|
|
|
|
call createHsOfficePartnerTestData('Hostsharing eG', 10001, 'First GmbH', 'first contact');
|
|
|
|
|
call createHsOfficePartnerTestData('Hostsharing eG', 10002, 'Second e.K.', 'second contact');
|
|
|
|
|
call createHsOfficePartnerTestData('Hostsharing eG', 10003, 'Third OHG', 'third contact');
|
|
|
|
|
call createHsOfficePartnerTestData('Hostsharing eG', 10004, 'Fourth eG', 'fourth contact');
|
|
|
|
|
call createHsOfficePartnerTestData('Hostsharing eG', 10010, 'Smith', 'fifth contact');
|
2022-09-09 10:40:05 +02:00
|
|
|
|
end;
|
|
|
|
|
$$;
|
|
|
|
|
--//
|