use strict; use Test::Collection; use Test::FakeData; use Test::More; use Data::Dumper; #use NGCP::Panel::Utils::Subscriber; my $test_machine = Test::Collection->new( name => 'subscribers', QUIET_DELETION => 1, ); my $fake_data = Test::FakeData->new; $test_machine->methods->{collection}->{allowed} = {map {$_ => 1} qw(GET HEAD OPTIONS POST)}; $test_machine->methods->{item}->{allowed} = {map {$_ => 1} qw(GET HEAD OPTIONS PUT PATCH DELETE)}; $fake_data->set_data_from_script({ 'subscribers' => { 'data' => { administrative => 0, customer_id => sub { return shift->get_id('customers',@_); }, primary_number => { ac => 111, cc=> 111, sn => 111 }, alias_numbers => [ { ac => 11, cc=> 11, sn => 11 } ], username => 'api_test_username', password => 'api_test_password', webusername => 'api_test_webusername', webpassword => undef, domain_id => sub { return shift->get_id('domains',@_); }, #domain_id => email => undef, external_id => undef, is_pbx_group => 1, is_pbx_pilot => 1, #sub { # my($self) = @_; # my $pilot = $self->test_machine->get_item_hal('subscribers','/api/subscribers/?customer_id='.$self->data->{$collection_name}->{data}->{customer_id}.'&'.'is_pbx_pilot=1'); # if($pilot->{content}->{total_count} > 0){ # return 0; # } # return 1; #}, pbx_extension => '111', pbx_group_ids => [], pbx_groupmember_ids => [], profile_id => sub { return shift->get_id('subscriberprofiles',@_); }, status => 'active', pbx_hunt_policy => 'parallel', pbx_hunt_timeout => '15', }, 'query' => [['username',{'query_type'=> 'string_like'}]], 'create_special'=> sub { my ($self,$collection_name,$test_machine) = @_; my $pilot = $test_machine->get_item_hal('subscribers','/api/subscribers/?customer_id='.$self->data->{$collection_name}->{data}->{customer_id}.'&'.'is_pbx_pilot=1'); if($pilot->{total_count} <= 0){ undef $pilot; } $test_machine->check_create_correct(1, sub{$_[0]->{is_pbx_pilot} = ($pilot || $_[1]->{i} > 1)? 0 : 1;} ); }, }, }); my $fake_data_processed = $fake_data->process('subscribers'); my $pilot = $test_machine->get_item_hal('subscribers','/api/subscribers/?customer_id='.$fake_data_processed->{customer_id}.'&'.'is_pbx_pilot=1'); if((exists $pilot->{total_count} && $pilot->{total_count}) || $pilot->{content}->{total_count} > 0){ $fake_data_processed->{is_pbx_pilot} = 0; #remove pilot aliases to don't intersect with them. On subscriber termination admin adopt numbers, see ticket#4967 $test_machine->request_patch( [ { op => 'replace', path => '/alias_numbers', value => [] } ], $pilot->{location} ); }else{ undef $pilot; } $test_machine->DATA_ITEM_STORE($fake_data_processed); $test_machine->form_data_item(); my $remote_config = $test_machine->init_catalyst_config; #modify time changes on every data change, and primary_number_id on every primary number change my $put2get_check_params = {ignore_fields => [qw/modify_timestamp create_timestamp primary_number_id/]}; { #20369 diag("20369: informative error for the PUT method on subscriber with duplicated number;\n\n"); my $members = $test_machine->check_create_correct( 2, sub{ my $num = $_[1]->{i}; $_[0]->{username} .= time().'_20369_'.$num ; $_[0]->{webusername} .= time().'_'.$num; $_[0]->{pbx_extension} .= '20369'.$num; $_[0]->{primary_number}->{ac} .= $num; $_[0]->{is_pbx_group} = 0; $_[0]->{is_pbx_pilot} = ($pilot || $_[1]->{i} > 1)? 0 : 1; $_[0]->{alias_numbers} = [{ ac => '111'.$num, cc=> 11, sn => 11 },{ ac => '112'.$num, cc=> 11, sn => 11 }]; } ); #$members->[1]->{content}->{primary_number} = $members->[0]->{content}->{primary_number}; #$members->[1]->{content}->{primary_number} = $members->[0]->{content}->{alias_numbers}->[0]; $members->[1]->{content}->{alias_numbers}->[0] = $members->[0]->{content}->{alias_numbers}->[0]; my ($res,$content,$request) = $test_machine->request_put(@{$members->[1]}{qw/content location/}); $test_machine->http_code_msg(422, "Check that PUT existing number will return nice error", $res, $content); #Number '11-1111-11' already exists ok($content->{message} =~ /Number ['\-\d]+ already exists/, "check error message in body"); $test_machine->clear_test_data_all();#fake data aren't registered in this test machine, so they will stay. } { # create new subscribers from DATA_ITEM. Item is not created in the fake_data->process. $test_machine->check_create_correct( 1, sub{ $_[0]->{username} .= time().'_'.$_[1]->{i} ; } ); $test_machine->check_bundle(); $test_machine->check_get2put(undef,{},$put2get_check_params); $test_machine->clear_test_data_all();#fake data aren't registered in this test machine, so they will stay. #remove pilot aliases to don't intersect with them. On subscriber termination admin adopt numbers, see ticket#4967 $pilot and $test_machine->request_patch( [ { op => 'replace', path => '/alias_numbers', value => [] } ], $pilot->{location} ); } #------- MT#15441 { diag("15441"); my $intentional_cli = '111'.time(); my $intentional_primary_number = { 'cc' => '111', 'ac' => '222', 'sn' => '1234'.time(), }; #prepare preconditions: cli should differ from primary_nuber #my $subscriber = ($test_machine->get_created_first() || $fake_data->get_existent_item($test_machine->name) || $test_machine->get_item_hal()); my $subscriber = $test_machine->check_create_correct(1, sub{ my $num = $_[1]->{i}; $_[0]->{username} .= time().'_15441' ; $_[0]->{webusername} .= time().'_15441'; $_[0]->{pbx_extension} .= '15441'; $_[0]->{primary_number}->{ac} .= $num; $_[0]->{customer_id} = $fake_data->get_id('customer_sipaccount'); } )->[0]; #print Dumper $subscriber; #die(); $subscriber->{uri} = $subscriber->{location}; my ($preferences, $preferences_put) = ({'uri' => '/api/subscriberpreferences/'.$test_machine->get_id_from_created($subscriber)}) x 2; (undef, $preferences->{content}) = $test_machine->check_item_get($preferences->{uri}); $preferences->{content}->{cli} = $intentional_cli; (undef, $preferences_put->{content}) = $test_machine->request_put($preferences->{content},$preferences->{uri}); is($preferences_put->{content}->{cli}, $intentional_cli, "check that cli was updated on subscriberpreferences put: $preferences_put->{content}->{cli} == $intentional_cli"); my ($subscriber_put, $subscriber_get, $preferences_get); #1 $subscriber->{content}->{primary_number} = $intentional_primary_number; $put2get_check_params->{compare_cb} = sub{ #$put_in->{content}, $put_get_out->{content}; my($put_in_content,$put_get_out_content) = @_; delete $put_get_out_content->{primary_number}->{number_id} if exists $put_get_out_content->{primary_number}; }; ($subscriber_put,$subscriber_get,$preferences_get) = $test_machine->put_and_get($subscriber, $preferences_put, $put2get_check_params); is($preferences_get->{content}->{cli}, $intentional_cli, "1. check that cli was preserved on subscriber phones update: $preferences_get->{content}->{cli} == $intentional_cli"); #/1 #2 delete $subscriber->{content}->{primary_number}; ($subscriber_put,$subscriber_get,$preferences_get) = $test_machine->put_and_get($subscriber, $preferences_put, $put2get_check_params); is($preferences_get->{content}->{cli}, $intentional_cli, "2. check that cli was preserved on subscriber phones update: $preferences_get->{content}->{cli} == $intentional_cli"); #/2 #now prepare preferences for zero situation, when synchronization will be restarted again delete $preferences->{content}->{cli}; (undef, $preferences_put->{content}) = $test_machine->request_put($preferences->{content},$preferences->{uri}); is($preferences_put->{content}->{cli}, undef, "check that cli was deleted on subscriberpreferences put with empty cli"); if($remote_config->{config}->{numbermanagement}->{auto_sync_cli}){ #3 $subscriber->{content}->{primary_number} = $intentional_primary_number; ($subscriber_put,$subscriber_get,$preferences_get) = $test_machine->put_and_get($subscriber, $preferences_put, $put2get_check_params); is($preferences_get->{content}->{cli}, number_as_string($intentional_primary_number), "check that cli was created on subscriber phones update: $preferences_get->{content}->{cli} == ".number_as_string($intentional_primary_number) ); #/3 $intentional_primary_number = { 'cc' => '222', 'ac' => '333', 'sn' => '444'.time(), }; #4 $subscriber->{content}->{primary_number} = $intentional_primary_number; ($subscriber_put,$subscriber_get,$preferences_get) = $test_machine->put_and_get($subscriber, $preferences_put, $put2get_check_params ); is($preferences_get->{content}->{cli}, number_as_string($intentional_primary_number), "check that cli was updated on subscriber phones update: $preferences_get->{content}->{cli} == ".number_as_string($intentional_primary_number) ); #/4 #5 delete $subscriber->{content}->{primary_number}; ($subscriber_put,$subscriber_get,$preferences_get) = $test_machine->put_and_get($subscriber, $preferences_put, $put2get_check_params); is($preferences_get->{content}->{cli}, undef, "check that cli was deleted on subscriber phones update"); #/5 } $test_machine->clear_test_data_all();#fake data aren't registered in this test machine, so they will stay. #remove pilot aliases to don't intersect with them. On subscriber termination admin adopt numbers, see ticket#4967 $pilot and $test_machine->request_patch( [ { op => 'replace', path => '/alias_numbers', value => [] } ], $pilot->{location} ); } if($remote_config->{config}->{features}->{cloudpbx}){ { #18601 diag("18601: config->features->cloudpbx: ".$remote_config->{config}->{features}->{cloudpbx}.";\n"); my $groups = $test_machine->check_create_correct( 3, sub{ my $num = $_[1]->{i}; $_[0]->{username} .= time().'_18601_'.$num ; $_[0]->{webusername} .= time().'_'.$num; $_[0]->{pbx_extension} .= '18601'.$num; $_[0]->{primary_number}->{ac} .= $num; $_[0]->{is_pbx_group} = 1; $_[0]->{is_pbx_pilot} = ($pilot || $_[1]->{i} > 1)? 0 : 1; delete $_[0]->{alias_numbers}; } ); my $members = $test_machine->check_create_correct( 3, sub{ my $num = 3 + $_[1]->{i}; $_[0]->{username} .= time().'_18601_'.$num ; $_[0]->{webusername} .= time().'_'.$num; $_[0]->{pbx_extension} .= '18601'.$num; $_[0]->{primary_number}->{ac} .= $num; $_[0]->{is_pbx_pilot} = 0; $_[0]->{is_pbx_group} = 0; delete $_[0]->{alias_numbers}; }); $members->[1]->{content}->{pbx_group_ids} = []; diag("1. Check that member will return empty groups after put groups empty"); my($member_put,$member_get) = $test_machine->check_put2get($members->[1],undef, $put2get_check_params); is_deeply( $members->[1]->{content}->{pbx_group_ids}, [], "Check that member will return empty groups after put groups empty"); $members->[1]->{content}->{pbx_group_ids} = [map { $groups->[$_]->{content}->{id} } (2,1)]; diag("2. Check that member will return groups as they were specified"); #fix for the 5415 prevents changing members order in the group, this is why resulting groups order for the member may differ from the input #($member_put,$member_get) = $test_machine->check_put2get($members->[1], undef, $put2get_check_params); my($res,$content) = $test_machine->request_put(@{$members->[1]}{qw/content location/}); $test_machine->http_code_msg(200, "PUT for members[1] was successful", $res, $content); my(undef, $members_1_after_touch) = $test_machine->check_item_get($members->[1]->{location}); #print Dumper [$members->[1]->{content}, $members_1_after_touch]; is_deeply( [sort @{$members->[1]->{content}->{pbx_group_ids}}], [sort @{$members_1_after_touch->{pbx_group_ids}}], "Check member groups after touch - the same cortege"); $groups->[1]->{content}->{pbx_groupmember_ids} = [map { $members->[$_]->{content}->{id} } (2,1,0)]; diag("3. Check that group will return members as they were specified"); my($group_put,$group_get) = $test_machine->check_put2get($groups->[1], undef, $put2get_check_params); $groups->[1]->{content}->{pbx_groupmember_ids} = []; diag("4. Check that group will return empty members after put members empty"); my($group_put,$group_get) = $test_machine->check_put2get($groups->[1], undef, $put2get_check_params); #5415 WF diag("5415: check that groups management doesn't change members order;\n"); diag("5415:Set members order for the group;\n"); $groups->[1]->{content}->{pbx_groupmember_ids} = [ map { $members->[$_]->{content}->{id} } ( 0, 2, 1 ) ]; ($group_put,$group_get)= $test_machine->check_put2get($groups->[1], undef, $put2get_check_params); diag("5415:Touch one of the members;\n"); $members->[2]->{content}->{pbx_group_ids} = [ map { $groups->[$_]->{content}->{id} } (2,1)]; #my($res,$content) = $test_machine->check_put2get($members->[2]); #fix for the 5415 prevents changing members order in the group, this is why resulting groups order for the member may differ from the input my($res,$content) = $test_machine->request_put(@{$members->[2]}{qw/content location/}); $test_machine->http_code_msg(200, "PUT for groups was successful", $res, $content); my(undef, $members_2_after_touch) = $test_machine->check_item_get($members->[2]->{location}); is_deeply( [sort @{$members->[2]->{content}->{pbx_group_ids}}], [sort @{$members_2_after_touch->{pbx_group_ids}}], "Check member groups after touch - the same cortege"); diag("5415:Check members order in the group;\n"); my(undef, $group_get_after) = $test_machine->check_item_get($groups->[1]->{location}); is_deeply($groups->[1]->{content}->{pbx_groupmember_ids}, $group_get_after->{pbx_groupmember_ids}, "Check group members order after touching it's member"); #7453 - we have modifications, so we can check modify_timestamp ok(length($members_2_after_touch->{create_timestamp}) > 8 , "check create_timestamp not empty ".$members_2_after_touch->{create_timestamp}); ok(length($members_2_after_touch->{modify_timestamp}) > 8 , "check modify_timestamp not empty ".$members_2_after_touch->{modify_timestamp}); $test_machine->clear_test_data_all();#fake data aren't registered in this test machine, so they will stay. } } #TT#8680 { diag("8680: check E164 fields format;\n"); my $data = clone $test_machine->DATA_ITEM; #TT#9066 $data->{primary_number} = ["12123132"]; my($res,$content) = $test_machine->request_post( $data); $test_machine->http_code_msg(422, "Pimary number should be a hash", $res, $content); #MT#22853 my $data = clone $test_machine->DATA_ITEM; $data->{alias_numbers} = ["49221222899813", "49221222899814", "49221222899814"]; my($res,$content) = $test_machine->request_post( $data); $test_machine->http_code_msg(422, "Alias numbers should be the hashs", $res, $content); } $fake_data->clear_test_data_all(); $test_machine->clear_test_data_all();#fake data aren't registered in this test machine, so they will stay. $fake_data->clear_test_data_all(); undef $test_machine; undef $fake_data; done_testing; sub number_as_string{ my ($number_row, %params) = @_; return 'HASH' eq ref $number_row ? $number_row->{cc} . ($number_row->{ac} // '') . $number_row->{sn} : $number_row->cc . ($number_row->ac // '') . $number_row->sn; } # vim: set tabstop=4 expandtab: