aboutsummaryrefslogtreecommitdiffstats
path: root/t/app/controller/auth_phone.t
blob: dea1c349394270356c5be99bc7e9a36277d82c9d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
use FixMyStreet::TestMech;

use t::Mock::Twilio;

my $twilio = t::Mock::Twilio->new;
LWP::Protocol::PSGI->register($twilio->to_psgi_app, host => 'api.twilio.com');

my $mech = FixMyStreet::TestMech->new;

FixMyStreet::override_config {
    SMS_AUTHENTICATION => 1,
    PHONE_COUNTRY => 'GB',
    TWILIO_ACCOUNT_SID => 'AC123',
}, sub {

    subtest 'Log in with invalid number, fail' => sub {
        $mech->get_ok('/auth');
        $mech->submit_form_ok({
            form_name => 'general_auth',
            fields => { username => '01214960000000' },
            button => 'sign_in_by_code',
        }, "sign in using bad number");
        $mech->content_contains('Please check your phone number is correct');
    };

    subtest 'Log in using landline, fail' => sub {
        $mech->get_ok('/auth');
        $mech->submit_form_ok({
            form_name => 'general_auth',
            fields => { username => '01214960000' },
            button => 'sign_in_by_code',
        }, "sign in using landline");
        $mech->content_contains('Please enter a mobile number');
    };

    subtest 'Log in using number that fails at Twilio' => sub {
        $mech->get_ok('/auth');
        $mech->submit_form_ok({
            form_name => 'general_auth',
            fields => { username => '+18165550101' },
            button => 'sign_in_by_code',
        }, "sign in using failing number");
        $mech->content_contains('Sending a confirmation text failed');
    };

    subtest 'Log in using mobile, by text' => sub {
        $mech->submit_form_ok({
            form_name => 'general_auth',
            fields => { username => '+18165550100', password_register => 'secret' },
            button => 'sign_in_by_code',
        }, "sign in using mobile");

        $mech->submit_form_ok({
            with_fields => { code => '00000' }
        }, 'submit incorrect code');
        $mech->content_contains('Try again');

        my $code = $twilio->get_text_code;
        $mech->submit_form_ok({
            with_fields => { code => $code }
        }, 'submit correct code');

        my $user = FixMyStreet::App->model('DB::User')->find( { phone => '+18165550100' } );
        ok $user, "user created";
        is $mech->uri->path, '/my', "redirected to the 'my' section of site";
        $mech->logged_in_ok;
        $mech->log_out_ok;
    };

    subtest 'Log in using mobile, by password' => sub {
        $mech->get_ok('/auth');
        $mech->submit_form_ok({
            form_name => 'general_auth',
            fields => { username => '+18165550100', password_sign_in => 'incorrect' },
            button => 'sign_in_by_password',
        }, "sign in using wrong password");
        $mech->content_contains('There was a problem');
        $mech->submit_form_ok({
            form_name => 'general_auth',
            fields => { username => '+18165550100', password_sign_in => 'secret' },
            button => 'sign_in_by_password',
        }, "sign in using password");

        is $mech->uri->path, '/my', "redirected to the 'my' section of site";
        $mech->logged_in_ok;
    };

};

done_testing();