Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
erp5
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Gabriel Monnerat
erp5
Commits
71cdc20c
Commit
71cdc20c
authored
May 25, 2015
by
Jérome Perrin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
testnode: simple log viewer app not to download the whole suite.log
parent
2a307846
Changes
4
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
219 additions
and
0 deletions
+219
-0
erp5/util/testnode/NodeTestSuite.py
erp5/util/testnode/NodeTestSuite.py
+3
-0
erp5/util/testnode/js-logtail/jquery.min.js
erp5/util/testnode/js-logtail/jquery.min.js
+4
-0
erp5/util/testnode/js-logtail/logtail.html
erp5/util/testnode/js-logtail/logtail.html
+20
-0
erp5/util/testnode/js-logtail/logtail.js
erp5/util/testnode/js-logtail/logtail.js
+192
-0
No files found.
erp5/util/testnode/NodeTestSuite.py
View file @
71cdc20c
...
...
@@ -97,6 +97,9 @@ class NodeTestSuite(SlapOSInstance):
suite_log_directory
=
os
.
path
.
join
(
self
.
log_directory
,
random_suite_folder_id
)
SlapOSControler
.
createFolders
(
suite_log_directory
)
# XXX copy the whole content of the log viewer app
for
fname
in
glob
.
glob
(
os
.
path
.
join
(
os
.
path
.
dirname
(
__file__
),
'js-logtail'
,
'*'
)):
shutil
.
copy
(
fname
,
suite_log_directory
)
self
.
suite_log_path
=
os
.
path
.
join
(
suite_log_directory
,
'suite.log'
)
return
self
.
getSuiteLogPath
(),
random_suite_folder_id
...
...
erp5/util/testnode/js-logtail/jquery.min.js
0 → 100644
View file @
71cdc20c
This diff is collapsed.
Click to expand it.
erp5/util/testnode/js-logtail/logtail.html
0 → 100644
View file @
71cdc20c
<!DOCTYPE html>
<!-- Taken from https://github.com/ukhas/js-logtail -->
<!-- Copyright (c) 2012 Daniel Richman; GNU GPL 3 -->
<html>
<head>
<title>
Test suite log viewer
</title>
<script
type=
"text/javascript"
src=
"jquery.min.js"
></script>
<script
type=
"text/javascript"
src=
"logtail.js"
></script>
</head>
<body>
<div
id=
"header"
>
Test Suite Log
<a
href=
"logtail.html"
>
Reversed
</a>
or
<a
href=
"logtail.html?noreverse"
>
chronological
</a>
view.
<a
id=
"pause"
href=
'#'
>
Pause
</a>
.
<a
href=
"suite.log"
>
Full log file
</a>
or
</div>
<pre
id=
"data"
style=
"font-size: xx-small;"
>
Loading...
</pre>
</body>
</html>
erp5/util/testnode/js-logtail/logtail.js
0 → 100644
View file @
71cdc20c
/* Copyright (c) 2012: Daniel Richman. License: GNU GPL 3 */
/* Additional features: Priyesh Patel */
(
function
()
{
var
dataelem
=
"
#data
"
;
var
pausetoggle
=
"
#pause
"
;
var
scrollelems
=
[
"
html
"
,
"
body
"
];
var
url
=
"
suite.log
"
;
var
fix_rn
=
true
;
var
load
=
30
*
1024
;
/* 30KB */
var
poll
=
1000
;
/* 1s */
var
kill
=
false
;
var
loading
=
false
;
var
pause
=
false
;
var
reverse
=
true
;
var
log_data
=
""
;
var
log_file_size
=
0
;
/* :-( https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/parseInt */
function
parseInt2
(
value
)
{
if
(
!
(
/^
[
0-9
]
+$/
.
test
(
value
)))
throw
"
Invalid integer
"
+
value
;
var
v
=
Number
(
value
);
if
(
isNaN
(
v
))
throw
"
Invalid integer
"
+
value
;
return
v
;
}
function
get_log
()
{
if
(
kill
|
loading
)
return
;
loading
=
true
;
var
range
;
var
first_load
;
var
must_get_206
;
if
(
log_file_size
===
0
)
{
/* Get the last 'load' bytes */
range
=
"
-
"
+
load
.
toString
();
first_load
=
true
;
must_get_206
=
false
;
}
else
{
/* Get the (log_file_size - 1)th byte, onwards. */
range
=
(
log_file_size
-
1
).
toString
()
+
"
-
"
;
first_load
=
false
;
must_get_206
=
log_file_size
>
1
;
}
/* The "log_file_size - 1" deliberately reloads the last byte, which we already
* have. This is to prevent a 416 "Range unsatisfiable" error: a response
* of length 1 tells us that the file hasn't changed yet. A 416 shows that
* the file has been trucnated */
$
.
ajax
(
url
,
{
dataType
:
"
text
"
,
cache
:
false
,
headers
:
{
Range
:
"
bytes=
"
+
range
},
success
:
function
(
data
,
s
,
xhr
)
{
loading
=
false
;
var
content_size
;
if
(
xhr
.
status
===
206
)
{
var
c_r
=
xhr
.
getResponseHeader
(
"
Content-Range
"
);
if
(
!
c_r
)
throw
"
Server did not respond with a Content-Range
"
;
log_file_size
=
parseInt2
(
c_r
.
split
(
"
/
"
)[
1
]);
content_size
=
parseInt2
(
xhr
.
getResponseHeader
(
"
Content-Length
"
));
}
else
if
(
xhr
.
status
===
200
)
{
if
(
must_get_206
)
throw
"
Expected 206 Partial Content
"
;
content_size
=
log_file_size
=
parseInt2
(
xhr
.
getResponseHeader
(
"
Content-Length
"
));
}
else
{
throw
"
Unexpected status
"
+
xhr
.
status
;
}
if
(
first_load
&&
data
.
length
>
load
)
throw
"
Server's response was too long
"
;
var
added
=
false
;
if
(
first_load
)
{
/* Clip leading part-line if not the whole file */
if
(
content_size
<
log_file_size
)
{
var
start
=
data
.
indexOf
(
"
\n
"
);
log_data
=
data
.
substring
(
start
+
1
);
}
else
{
log_data
=
data
;
}
added
=
true
;
}
else
{
/* Drop the first byte (see above) */
log_data
+=
data
.
substring
(
1
);
if
(
log_data
.
length
>
load
)
{
var
start
=
log_data
.
indexOf
(
"
\n
"
,
log_data
.
length
-
load
);
log_data
=
log_data
.
substring
(
start
+
1
);
}
if
(
data
.
length
>
1
)
added
=
true
;
}
if
(
added
)
show_log
(
added
);
setTimeout
(
get_log
,
poll
);
},
error
:
function
(
xhr
,
s
,
t
)
{
loading
=
false
;
if
(
xhr
.
status
===
416
||
xhr
.
status
==
404
)
{
/* 416: Requested range not satisfiable: log was truncated. */
/* 404: Retry soon, I guess */
log_file_size
=
0
;
log_data
=
""
;
show_log
();
setTimeout
(
get_log
,
poll
);
}
else
{
throw
"
Unknown AJAX Error (status
"
+
xhr
.
status
+
"
)
"
;
}
}
});
}
function
scroll
(
where
)
{
for
(
var
i
=
0
;
i
<
scrollelems
.
length
;
i
++
)
{
var
s
=
$
(
scrollelems
[
i
]);
if
(
where
===
-
1
)
s
.
scrollTop
(
s
.
height
());
else
s
.
scrollTop
(
where
);
}
}
function
show_log
()
{
if
(
pause
)
return
;
var
t
=
log_data
;
if
(
reverse
)
{
var
t_a
=
t
.
split
(
/
\n
/g
);
t_a
.
reverse
();
if
(
t_a
[
0
]
==
""
)
t_a
.
shift
();
t
=
t_a
.
join
(
"
\n
"
);
}
if
(
fix_rn
)
t
=
t
.
replace
(
/
\n
/g
,
"
\r\n
"
);
$
(
dataelem
).
text
(
t
);
if
(
!
reverse
)
scroll
(
-
1
);
}
function
error
(
what
)
{
kill
=
true
;
$
(
dataelem
).
text
(
"
An error occured :-(.
\r\n
"
+
"
Reloading may help; no promises.
\r\n
"
+
what
);
scroll
(
0
);
return
false
;
}
$
(
document
).
ready
(
function
()
{
window
.
onerror
=
error
;
/* If URL is /logtail/?noreverse display in chronological order */
var
hash
=
location
.
search
.
replace
(
/^
\?
/
,
""
);
if
(
hash
==
"
noreverse
"
)
reverse
=
false
;
/* Add pause toggle */
$
(
pausetoggle
).
click
(
function
(
e
)
{
pause
=
!
pause
;
$
(
pausetoggle
).
text
(
pause
?
"
Unpause
"
:
"
Pause
"
);
show_log
();
e
.
preventDefault
();
});
get_log
();
});
})();
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment