use Test::More; use strict; use IO::String; use JSON; BEGIN { require 't/test-lib.pm'; } my $res; my $file = '{ "rules": { "^/deny": "deny", "^/testno": "$uid ne qq#dwho#", "^/testyes": "$uid eq qq#dwho#", "default": "accept" }, "headers": { "User": "$uid", "Mail": "$mail", "Name": "$cn", "LDAP_Var": "$ldapExpVar", "Groups_SSO": "$groups", "UA": "$UA ? $UA : qq#FF#" } }'; my $bad_file = '{ "rules": { "^/testno": "$uid ne qq#dwho#" "default": "accept" }, "headers": { "User": "$uid", } }'; my $bad_file2 = qq%{ "rules": { "default": "accept" }, "headers": { "User": "'user", "Mail": "'mail'" } }%; my $bad_file3 = q%{ "rule": { "default": "accept" }, "headers": { "User": "'user", "Mail": "'mail'" } }%; my $bad_file4 = q%{ "rules": { "default": "accept" }, "headers": { "test": "$none", "bad": "$test ? $other : $dalek" } }%; my $client = LLNG::Manager::Test->new( { ini => { logLevel => 'error', authentication => 'Demo', userDB => 'Same', requireToken => 1, checkDevOps => 1, checkDevOpsDownload => 0, checkDevOpsDisplayNormalizedHeaders => 0, hiddenAttributes => 'mail, UA', ldapExportedVars => { ldapExpVar => '' } } } ); ## Try to authenticate ok( $res = $client->_get( '/', accept => 'text/html' ), 'Get Menu', ); count(1); my ( $host, $url, $query ) = expectForm( $res, '#', undef, 'user', 'password', 'token' ); $query =~ s/user=/user=dwho/; $query =~ s/password=/password=dwho/; ok( $res = $client->_post( '/', IO::String->new($query), length => length($query), accept => 'text/html', ), 'Auth query' ); count(1); my $id = expectCookie($res); expectRedirection( $res, 'http://auth.example.com/' ); # CheckDevOps form # ---------------- ok( $res = $client->_get( '/checkdevops', cookie => "lemonldap=$id", accept => 'text/html' ), 'CheckDevOps form', ); ( $host, $url, $query ) = expectForm( $res, undef, '/checkdevops', 'checkDevOpsFile', 'token' ); ok( $res->[2]->[0] =~ m%%, 'Found trspan="checkDevOps"' ) or explain( $res->[2]->[0], 'trspan="checkDevOps"' ); count(2); # POST without token # ------------------ ok( $res = $client->_post( '/checkdevops', IO::String->new(''), cookie => "lemonldap=$id", length => 0, accept => 'text/html' ), 'POST checkdevops without token' ); ok( $res->[2]->[0] =~ m%[2]->[0], 'trspan="PE81"' ); count(2); ( $host, $url, $query ) = expectForm( $res, undef, '/checkdevops', 'checkDevOpsFile', 'token' ); # POST bad file # ------------- $query .= "&checkDevOpsFile=$bad_file"; ok( $res = $client->_post( '/checkdevops', IO::String->new($query), cookie => "lemonldap=$id", length => length($query), accept => 'text/html' ), 'POST checkdevops with bad file' ); ok( $res->[2]->[0] =~ m%%, 'Found PE_BAD_DEVOPS_FILE' ) or explain( $res->[2]->[0], 'trspan="PE104"' ); count(2); ( $host, $url, $query ) = expectForm( $res, undef, '/checkdevops', 'checkDevOpsFile', 'token' ); # POST bad file2 # -------------- $query .= "&checkDevOpsFile=$bad_file2"; ok( $res = $client->_post( '/checkdevops', IO::String->new($query), cookie => "lemonldap=$id", length => length($query), accept => 'text/html' ), 'POST checkdevops with bad file2' ); ok( $res->[2]->[0] =~ m%%, 'Found PE_BAD_DEVOPS_FILE' ) or explain( $res->[2]->[0], 'trspan="PE104"' ); count(2); ( $host, $url, $query ) = expectForm( $res, undef, '/checkdevops', 'checkDevOpsFile', 'token' ); # POST bad file3 # -------------- $query .= "&checkDevOpsFile=$bad_file3"; ok( $res = $client->_post( '/checkdevops', IO::String->new($query), cookie => "lemonldap=$id", length => length($query), accept => 'text/html' ), 'POST checkdevops with bad file3' ); ok( $res->[2]->[0] =~ m%%, 'Found PE_BAD_DEVOPS_FILE' ) or explain( $res->[2]->[0], 'trspan="PE104"' ); count(2); ( $host, $url, $query ) = expectForm( $res, undef, '/checkdevops', 'checkDevOpsFile', 'token' ); # POST bad file4 # -------------- $query .= "&checkDevOpsFile=$bad_file4"; ok( $res = $client->_post( '/checkdevops', IO::String->new($query), cookie => "lemonldap=$id", length => length($query), accept => 'text/html' ), 'POST checkdevops with bad file4' ); ok( $res->[2]->[0] =~ m%%, 'Found PE_BAD_DEVOPS_FILE' ) or explain( $res->[2]->[0], 'trspan="PE104"' ); ok( $res->[2]->[0] =~ m%%, 'Found unknownAttributes' ) or explain( $res->[2]->[0], 'trspan="unknownAttributes"' ); ok( $res->[2]->[0] =~ m%dalek; none; other; test%, 'Found 4 unknown attributes' ) or explain( $res->[2]->[0], 'Unknown attributes' ); count(4); ( $host, $url, $query ) = expectForm( $res, undef, '/checkdevops', 'checkDevOpsFile', 'token' ); # POST file # --------- $query .= "&checkDevOpsFile=$file"; ok( $res = $client->_post( '/checkdevops', IO::String->new($query), cookie => "lemonldap=$id", length => length($query), accept => 'text/html' ), 'POST checkdevops with file' ); ok( $res->[2]->[0] =~ m%