1
0

DoesTesting.pm 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. package Test::Selenium::Remote::Role::DoesTesting;
  2. # ABSTRACT: Role to cope with everything that is related to testing (could
  3. # be reused in both testing classes)
  4. use Moo::Role;
  5. use Test::Builder;
  6. use Try::Tiny;
  7. use List::MoreUtils qw/any/;
  8. use namespace::clean;
  9. requires qw(func_list has_args);
  10. has _builder => (
  11. is => 'lazy',
  12. builder => sub { return Test::Builder->new() },
  13. handles => [qw/is_eq isnt_eq like unlike ok croak/],
  14. );
  15. # get back the key value from an already coerced finder (default finder)
  16. sub _get_finder_key {
  17. my $self = shift;
  18. my $finder_value = shift;
  19. foreach my $k (keys %{$self->FINDERS}) {
  20. return $k if ($self->FINDERS->{$k} eq $finder_value);
  21. }
  22. return;
  23. }
  24. # main method for non ok tests
  25. sub _check_method {
  26. my $self = shift;
  27. my $method = shift;
  28. my $method_to_test = shift;
  29. $method = "get_$method";
  30. my @args = @_;
  31. my $rv;
  32. try {
  33. my $num_of_args = $self->has_args($method);
  34. my @r_args = splice( @args, 0, $num_of_args );
  35. $rv = $self->$method(@r_args);
  36. }
  37. catch {
  38. $self->croak($_);
  39. };
  40. return $self->$method_to_test( $rv, @args );
  41. }
  42. # main method for _ok tests
  43. # a bit hacked so that find_no_element_ok can also be processed
  44. sub _check_ok {
  45. my $self = shift;
  46. my $method = shift;
  47. my $real_method = '';
  48. my @args = @_;
  49. my ($rv, $num_of_args, @r_args);
  50. try {
  51. $num_of_args = $self->has_args($method);
  52. @r_args = splice( @args, 0, $num_of_args );
  53. if ($method =~ m/^find(_no|_child)?_element/) {
  54. # case find_element_ok was called with no arguments
  55. if (scalar(@r_args) - $num_of_args == 1) {
  56. push @r_args, $self->_get_finder_key($self->default_finder);
  57. }
  58. else {
  59. if (scalar(@r_args) == $num_of_args) {
  60. # case find_element was called with no finder but
  61. # a test description
  62. my $finder = $r_args[$num_of_args - 1];
  63. my @FINDERS = keys (%{$self->FINDERS});
  64. unless ( any { $finder eq $_ } @FINDERS) {
  65. $r_args[$num_of_args - 1] = $self->_get_finder_key($self->default_finder);
  66. push @args, $finder;
  67. }
  68. }
  69. }
  70. }
  71. # quick hack to fit 'find_no_element' into check_ok logic
  72. if ($method eq 'find_no_element') {
  73. $real_method = $method;
  74. $method = 'find_element';
  75. }
  76. $rv = $self->$method(@r_args);
  77. }
  78. catch {
  79. if ($real_method) {
  80. $method = $real_method;
  81. $rv = 1;
  82. }
  83. else {
  84. $self->croak($_);
  85. }
  86. };
  87. my $default_test_name = $method;
  88. $default_test_name .= "'" . join("' ", @r_args) . "'"
  89. if $num_of_args > 0;
  90. my $test_name = pop @args // $default_test_name;
  91. return $self->ok( $rv, $test_name);
  92. }
  93. # build the subs with the correct arg set
  94. sub _build_sub {
  95. my $self = shift;
  96. my $meth_name = shift;
  97. my @func_args;
  98. my $comparators = {
  99. is => 'is_eq',
  100. isnt => 'isnt_eq',
  101. like => 'like',
  102. unlike => 'unlike',
  103. };
  104. my @meth_elements = split( '_', $meth_name );
  105. my $meth = '_check_ok';
  106. my $meth_comp = pop @meth_elements;
  107. if ( $meth_comp eq 'ok' ) {
  108. push @func_args, join( '_', @meth_elements );
  109. }
  110. else {
  111. if ( defined( $comparators->{$meth_comp} ) ) {
  112. $meth = '_check_method';
  113. push @func_args, join( '_', @meth_elements ),
  114. $comparators->{$meth_comp};
  115. }
  116. else {
  117. return sub {
  118. my $self = shift;
  119. $self->croak("Sub $meth_name could not be defined");
  120. }
  121. }
  122. }
  123. return sub {
  124. my $self = shift;
  125. local $Test::Builder::Level = $Test::Builder::Level + 2;
  126. $self->$meth( @func_args, @_ );
  127. };
  128. }
  129. 1;
  130. =head1 NAME
  131. Selenium::Remote::Role::DoesTesting - Role implementing the common logic used for testing
  132. =cut