Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
E
erp5_workflow
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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wenjie.zheng
erp5_workflow
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