diff options
author | Matthew Somerville <matthew-github@dracos.co.uk> | 2019-01-18 14:55:14 +0000 |
---|---|---|
committer | Matthew Somerville <matthew-github@dracos.co.uk> | 2019-01-23 10:06:32 +0000 |
commit | f44ad2f067346cb3b03d3711fd658a5516e9fd0c (patch) | |
tree | 1667dcb3f8ce0342e3b08a98c809555d9775e58b /t | |
parent | bddeaa7f8b8f495879df99eb5a85828c862f071e (diff) |
[Open311] Refactor cobrand specific code.
Diffstat (limited to 't')
-rw-r--r-- | t/cobrand/warwickshire.t | 84 | ||||
-rw-r--r-- | t/open311/populate-service-list.t | 6 |
2 files changed, 89 insertions, 1 deletions
diff --git a/t/cobrand/warwickshire.t b/t/cobrand/warwickshire.t new file mode 100644 index 000000000..79c9f31e0 --- /dev/null +++ b/t/cobrand/warwickshire.t @@ -0,0 +1,84 @@ +#!/usr/bin/env perl + +use FixMyStreet::Test; +use FixMyStreet::DB; + +use_ok( 'Open311::PopulateServiceList' ); +use_ok( 'Open311' ); + +my $processor = Open311::PopulateServiceList->new(); +ok $processor, 'created object'; + +my $warks = FixMyStreet::DB->resultset('Body')->create({ + name => 'Warwickshire County Council', +}); +$warks->body_areas->create({ area_id => 2243 }); + +subtest 'check Warwickshire override' => sub { + my $processor = Open311::PopulateServiceList->new(); + + my $meta_xml = '<?xml version="1.0" encoding="utf-8"?> +<service_definition> + <service_code>100</service_code> + <attributes> + <attribute> + <variable>true</variable> + <code>closest_address</code> + <datatype>string</datatype> + <required>true</required> + <order>1</order> + <description>Closest address</description> + </attribute> + <attribute> + <variable>true</variable> + <code>size</code> + <datatype>string</datatype> + <required>true</required> + <order>2</order> + <description>How big is the pothole</description> + </attribute> + </attributes> +</service_definition> + '; + + my $contact = FixMyStreet::DB->resultset('Contact')->create({ + body_id => $warks->id, + email => '100', + category => 'Pothole', + state => 'confirmed', + editor => $0, + whenedited => \'current_timestamp', + note => 'test contact', + }); + + my $o = Open311->new( + jurisdiction => 'mysociety', + endpoint => 'http://example.com', + test_mode => 1, + test_get_returns => { 'services/100.xml' => $meta_xml } + ); + + $processor->_current_open311( $o ); + FixMyStreet::override_config { + ALLOWED_COBRANDS => [ 'warwickshire' ], + }, sub { + $processor->_current_body( $warks ); + }; + $processor->_current_service( { service_code => 100, service_name => 'Pothole' } ); + $processor->_add_meta_to_contact( $contact ); + + my $extra = [ { + variable => 'true', + code => 'size', + datatype => 'string', + required => 'true', + order => 2, + description => 'How big is the pothole', + } ]; + + $contact->discard_changes; + is_deeply $contact->get_extra_fields, $extra, 'No closest_address field returned for Warks'; + is $contact->get_extra_metadata('id_field'), 'external_id', 'id_field set correctly'; +}; + +done_testing(); diff --git a/t/open311/populate-service-list.t b/t/open311/populate-service-list.t index 1415c7b2a..340a91ac5 100644 --- a/t/open311/populate-service-list.t +++ b/t/open311/populate-service-list.t @@ -552,7 +552,11 @@ subtest 'check Bromley skip code' => sub { ); $processor->_current_open311( $o ); - $processor->_current_body( $bromley ); + FixMyStreet::override_config { + ALLOWED_COBRANDS => [ 'bromley' ], + }, sub { + $processor->_current_body( $bromley ); + }; $processor->_current_service( { service_code => 100 } ); $processor->_add_meta_to_contact( $contact ); |