/[Frey]/branches/no-pager/lib/Frey/Test/Runner.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Contents of /branches/no-pager/lib/Frey/Test/Runner.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 738 - (show annotations)
Sat Dec 6 15:29:10 2008 UTC (15 years, 5 months ago) by dpavlin
File size: 4112 byte(s)
 r3584@llin (orig r703):  dpavlin | 2008-12-03 22:24:09 +0100
 rename
 r3585@llin (orig r704):  dpavlin | 2008-12-03 22:26:29 +0100
 document bin/log.sh
 r3586@llin (orig r705):  dpavlin | 2008-12-03 22:36:12 +0100
 fix paths for created class
 r3587@llin (orig r706):  dpavlin | 2008-12-03 22:52:49 +0100
 http://upload.wikimedia.org/wikipedia/commons/0/05/WikEd_fix_html.png
 r3588@llin (orig r707):  dpavlin | 2008-12-03 23:20:46 +0100
 last point for 0.24 and forward
 r3589@llin (orig r708):  dpavlin | 2008-12-03 23:23:26 +0100
 dump html content in textarea
 r3590@llin (orig r709):  dpavlin | 2008-12-03 23:24:19 +0100
 Cleanup all attributes from html
 r3591@llin (orig r710):  dpavlin | 2008-12-04 14:26:57 +0100
 added cookie killer described on my blog at
 https://blog.rot13.org/2006/11/clean_all_http_cookies_and_kill_session.html
 r3592@llin (orig r711):  dpavlin | 2008-12-04 17:02:09 +0100
 add created classes to svk by default
 r3593@llin (orig r712):  dpavlin | 2008-12-04 17:02:57 +0100
 convert form to post, so we don't have double action on next submit (one from get, one from post)
 r3594@llin (orig r713):  dpavlin | 2008-12-04 17:17:48 +0100
 add SlideShare favourites url
 r3595@llin (orig r714):  dpavlin | 2008-12-04 17:28:31 +0100
 fix dependency display
 r3596@llin (orig r715):  dpavlin | 2008-12-04 18:33:39 +0100
 hide _private attributes
 r3597@llin (orig r716):  dpavlin | 2008-12-04 18:35:12 +0100
 separate results_as_data from as_markup to make data reusable
 r3598@llin (orig r717):  dpavlin | 2008-12-04 18:55:27 +0100
 Split run to own line
 r3599@llin (orig r718):  dpavlin | 2008-12-04 19:33:25 +0100
 use_ok correct test
 r3600@llin (orig r719):  dpavlin | 2008-12-04 19:39:37 +0100
 wrap File::Slurp into Frey::File
 r3601@llin (orig r720):  dpavlin | 2008-12-04 21:20:45 +0100
 move checkbox to Frey::Web, fix multiple file commit
 r3602@llin (orig r721):  dpavlin | 2008-12-04 23:31:06 +0100
 fix Frey::File
 r3603@llin (orig r722):  dpavlin | 2008-12-04 23:37:26 +0100
 concepts
 r3604@llin (orig r723):  dpavlin | 2008-12-05 00:09:52 +0100
 mode pod
 r3605@llin (orig r724):  dpavlin | 2008-12-05 18:25:05 +0100
 display pod table of content
 r3606@llin (orig r725):  dpavlin | 2008-12-05 18:33:01 +0100
 fix warnings and take title for icon if it's not specified
 r3607@llin (orig r726):  dpavlin | 2008-12-05 18:34:10 +0100
 Fix output wrapping
 r3608@llin (orig r727):  dpavlin | 2008-12-05 18:34:43 +0100
 sort methods and attributes
 r3609@llin (orig r728):  dpavlin | 2008-12-06 01:19:32 +0100
 support check of single file
 r3610@llin (orig r729):  dpavlin | 2008-12-06 01:20:20 +0100
 more documentation, unfinished
 r3611@llin (orig r730):  dpavlin | 2008-12-06 01:21:36 +0100
 version bump [0.24]
 r3612@llin (orig r731):  dpavlin | 2008-12-06 01:25:19 +0100
 implement CSS2 form layout and support for undef (action support is still broken)
 r3613@llin (orig r732):  dpavlin | 2008-12-06 01:26:12 +0100
 simple two step action as still non-working prototype
 r3614@llin (orig r733):  dpavlin | 2008-12-06 01:43:29 +0100
 change yaml dump format, cleanup
 r3615@llin (orig r734):  dpavlin | 2008-12-06 01:57:49 +0100
 turn short lists to radio boxes
 r3616@llin (orig r735):  dpavlin | 2008-12-06 13:22:36 +0100
 css for documentation, always re-create introspect yaml
 r3617@llin (orig r736):  dpavlin | 2008-12-06 15:34:41 +0100
 put documentation in own line
 r3618@llin (orig r737):  dpavlin | 2008-12-06 15:35:15 +0100
 make commit form transparent so we can see diff behind it

1 package Frey::Test::Runner;
2 use Moose;
3
4 extends 'Frey';
5 with 'Frey::Web';
6 with 'Frey::Storage';
7
8 use TAP::Harness;
9 use TAP::Formatter::HTML;
10 use Data::Dump qw/dump/;
11 use File::Slurp;
12
13 use Frey::SVK;
14 use Frey::PPI;
15
16 has tests => (
17 is => 'rw',
18 isa => 'ArrayRef[Str]',
19 required => 1,
20 lazy => 1, # FIXME ask users which tests to run
21 default => sub {
22 [ Frey::SVK->modified ]
23 },
24 documentation => 'run tests which are result of modifications or whole full tests',
25 );
26
27 has test => (
28 is => 'rw',
29 isa => 'Str',
30 documentation => 'run only this single test',
31 );
32
33 has test_because => (
34 documentation => 'returns classes responsable for each test run',
35 is => 'rw',
36 # isa => 'HashRef[Hashref[Int]',
37 required => 1,
38 lazy => 1,
39 default => sub {
40 my $self = shift;
41 my $depends;
42
43 # collect real tests
44 map {
45 $depends->{$_}->{'test modified'}++ if m{\.t$};
46 } @{ $self->tests };
47
48 # and tests which depend on modified classes supplied
49 map {
50 if ( m{(.+)\.pm$} ) {
51 my $class = $1;
52 $class =~ s{^lib/}{};
53 $class =~ s{/}{::}g;
54 warn "extract tests from $_ class $class";
55 $depends->{$_}->{$class}++ foreach Frey::PPI->new( class => $class )->has_tests;
56 }
57 } @{ $self->tests };
58
59 return $depends;
60 },
61 );
62
63 sub as_markup {
64 my ($self) = @_;
65
66 =for later
67
68 my $path = 'var/test/';
69 my $running_pid = "$path/running.pid";
70
71 my $pid = read_file $running_pid if -e $running_pid;
72 if ( $pid ) {
73 if ( kill 0, $pid ) {
74 warn "ABORTING: $self allready running as pid $pid";
75 return 'abort';
76 } else {
77 warn "got $pid from $running_pid but no process alive, ignoring...";
78 }
79 }
80
81 write_file( $running_pid, $$ );
82 warn "# started $self with pid $$ -> $running_pid";
83
84 =cut
85
86 my $f = TAP::Formatter::HTML->new({
87 # silent => 1,
88
89 inline_css => 1,
90 inline_js => 0,
91 });
92 my $h = TAP::Harness->new({
93 merge => 1,
94 formatter => $f,
95 });
96
97 my @tests;
98
99 @tests = ( $self->test ) if $self->test;
100
101 if ( my $depends = $self->test_because ) {
102 @tests = grep {
103 $_ ne '' &&
104 ! m{$0} # break recursion
105 } sort keys %{ $depends } unless @tests;
106 }
107
108 $self->add_status( { test => { depends => $self->test_because } } );
109
110 if ( ! @tests ) {
111 warn "can't find any tests ", dump( $self->tests ), " within depends ", dump( $self->test_because );
112 # warn "running all tests instead";
113 # @tests = glob('t/*.t');
114 @tests = ( qw{t/00-load.t t/pod.t} ); # XXX default tests
115 }
116
117 $self->title( join(' ', @tests ) );
118
119 warn "testing ",dump( @tests );
120 $h->runtests( @tests );
121
122 $self->store( 'var/test/' . time() . '.yaml', $h );
123
124 my $html = ${ $f->html };
125 # warn $html;
126 warn "got ",length($html), " bytes";
127
128 while ( $html =~ s{(<style.+?/style>)}{}gs ) {
129 my $style = $1;
130 $style =~ s[((?:body|html)\s+{[^}]+})][/\* $1 \*/]sg; # remove some styles
131 $self->add_head( $style );
132 }
133
134 $self->add_head(qq|
135 <style type="text/css">
136 /* CSS to show-hide full text results */
137 ul.test-out { display: none; }
138 td.results:hover ul.test-out { display: block; }
139 </style>
140 |);
141 $html =~ s{<div id="menu">.+?</div>}{}sg; # remove menu which doesn't work without JavaScript
142
143 $html =~ s{^.*<body>}{}s;
144 $html =~ s{</body>.*$}{}s;
145
146 $html =~ s{(<a class="file") href="#"(.+?)>t/(.+?)</a>}{<a target="editor" href="/editor+t/$3.t+1" name="t/$3.t" $2>$3</a>}sg;
147
148 $html = $self->html_links( $html );
149
150 if ( my $depends = $self->test_because ) {
151 $html .= qq|Test dependencies:|
152 . qq|<ul><li>|
153 . join("</li>\n<li>",
154 map {
155 my $test = $_;
156 my $depends =
157 join(' ',
158 map {
159 if ( m{\s} ) {
160 $_ # human comment with space
161 } else {
162 qq|<a target="introspect" href="/$_" title="introspect">$_</a>|
163 # qq|<a target="editor" href="/editor+$_+1" title="edit">$_</a>|
164 }
165 } keys %{ $depends->{$_} }
166 );
167 qq|<a href="?test=$test"><tt>$test</tt></a>|
168 . ( $depends ? qq| &larr; $depends| : '' )
169 ;
170 } @tests )
171 . qq|</li></ul>|
172 ;
173 } else {
174 warn "# test_because empty";
175 }
176
177 $self->add_icon( $1 ) if $html =~ m{class="(passed|failed)"};
178
179 =for later
180
181 unlink $running_pid or die "can't remove $running_pid: $!";
182
183 =cut
184
185 return $html;
186 }
187
188 1;

  ViewVC Help
Powered by ViewVC 1.1.26