Skip to content
Toggle navigation
Toggle navigation
This project
Loading...
Sign in
John McEleney
/
casperjs
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Graphs
Issues
0
Merge Requests
0
Wiki
Network
Create a new issue
Builds
Commits
Issue Boards
Files
Commits
Network
Compare
Branches
Tags
Commit
3ca19aeb
...
3ca19aeb8648d4ce38bf9d6831a0758baedf2d8c
authored
2013-02-23 12:31:56 +0100
by
Nicolas Perriault
Browse Files
Options
Browse Files
Tag
Download
Email Patches
Plain Diff
PhantomJS 1.8 is now the minimum required version
1 parent
107eedf4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
56 additions
and
26 deletions
CHANGELOG.md
bin/bootstrap.js
bin/casperjs
bin/usage.txt
CHANGELOG.md
View file @
3ca19ae
...
...
@@ -8,6 +8,10 @@ This version is yet to be released, and will possibly be tagged as 2.0 as not-so
### Important Changes & Caveats
#### Minimum PhantomJS version
**PhantomJS 1.8.1 or later is required for 1.1.**
#### Testing framework refactoring
A new
`Tester.begin()`
method has been introduced to help organizing tests better:
...
...
@@ -64,6 +68,7 @@ Last, all the casper test suites have been upgraded to use the new testing featu
### Bugfixes & enhancements
-
heavy lifint of casperjs bootstrap script
-
closed
[
#392
](
https://github.com/n1k0/casperjs/issues/392
)
-
`--direct`
&
`--log-level`
options available for the
`casperjs`
executable
-
closed
[
#350
](
https://github.com/n1k0/casperjs/issues/350
)
- Add a Casper.waitForSelectorTextChange() method
-
fixed
[
#387
](
https://github.com/n1k0/casperjs/issues/387
)
- Setting viewport isn't quite synchronous
...
...
bin/bootstrap.js
View file @
3ca19ae
...
...
@@ -34,13 +34,6 @@
// phantom check
if
(
!
phantom
)
{
console
.
error
(
'CasperJS needs to be executed in a PhantomJS environment http://phantomjs.org/'
);
phantom
.
exit
(
1
);
}
// required version check
if
(
phantom
.
version
.
major
===
1
&&
phantom
.
version
.
minor
<
7
)
{
console
.
error
(
'CasperJS needs at least PhantomJS v1.7 or later.'
);
phantom
.
exit
(
1
);
}
// Common polyfills
...
...
@@ -75,6 +68,29 @@ CasperError.prototype = Object.getPrototypeOf(new Error());
return
;
}
function
__die
(
message
)
{
console
.
error
(
message
);
phantom
.
exit
(
1
);
}
function
__terminate
(
message
)
{
console
.
log
(
message
);
phantom
.
exit
();
}
(
function
(
version
)
{
// required version check
if
(
version
.
major
!==
1
)
{
return
__die
(
'CasperJS needs PhantomJS v1.x'
);
}
if
(
version
.
minor
<
8
)
{
return
__die
(
'CasperJS needs at least PhantomJS v1.8 or later.'
);
}
if
(
version
.
patch
<
1
)
{
return
__die
(
'CasperJS needs at least PhantomJS v1.8.1 or later.'
);
}
})(
phantom
.
version
);
// Hooks in default phantomjs error handler to print a hint when a possible
// casperjs command misuse is detected.
phantom
.
onError
=
function
onPhantomError
(
msg
,
trace
)
{
...
...
@@ -124,17 +140,19 @@ CasperError.prototype = Object.getPrototypeOf(new Error());
return
fs
.
isDirectory
(
path
);
}).
pop
();
}
catch
(
e
)
{
console
.
error
(
"Couldn't find nor compute phantom.casperPath, exiting."
);
phantom
.
exit
(
1
);
return
__die
(
"Couldn't find nor compute phantom.casperPath, exiting."
);
}
}
// Patched require to allow loading of native casperjs modules.
// Every casperjs native module have to first call this function in order to
// load a native casperjs module:
//
// var require = patchRequire(require);
// var utils = require('utils');
/**
* Patched require to allow loading of native casperjs modules.
* Every casperjs native module have to first call this function in order to
* load a native casperjs module:
*
* var require = patchRequire(require);
* var utils = require('utils');
*
*/
function
patchRequire
(
require
)
{
if
(
require
.
patched
)
{
return
require
;
...
...
@@ -168,6 +186,7 @@ CasperError.prototype = Object.getPrototypeOf(new Error());
/**
* Initializes the CasperJS Command Line Interface.
*
*/
function
initCasperCli
()
{
var
baseTestsPath
=
fs
.
pathJoin
(
phantom
.
casperPath
,
'tests'
);
...
...
@@ -190,11 +209,13 @@ CasperError.prototype = Object.getPrototypeOf(new Error());
}
else
if
(
phantom
.
casperArgs
.
args
.
length
===
0
||
!!
phantom
.
casperArgs
.
options
.
help
)
{
var
phantomVersion
=
[
phantom
.
version
.
major
,
phantom
.
version
.
minor
,
phantom
.
version
.
patch
].
join
(
'.'
);
var
f
=
require
(
"utils"
).
format
;
console
.
log
(
f
(
'CasperJS version %s at %s, using PhantomJS version %s'
,
phantom
.
casperVersion
.
toString
(),
phantom
.
casperPath
,
phantomVersion
));
console
.
log
(
fs
.
read
(
fs
.
pathJoin
(
phantom
.
casperPath
,
'bin'
,
'usage.txt'
)));
return
phantom
.
exit
(
0
);
return
__terminate
([
f
(
'CasperJS version %s at %s, using PhantomJS version %s'
,
phantom
.
casperVersion
.
toString
(),
phantom
.
casperPath
,
phantomVersion
)
,
fs
.
read
(
fs
.
pathJoin
(
phantom
.
casperPath
,
'bin'
,
'usage.txt'
))
].
join
(
'\n'
));
}
if
(
!
phantom
.
casperScript
)
{
...
...
@@ -202,8 +223,7 @@ CasperError.prototype = Object.getPrototypeOf(new Error());
}
if
(
!
fs
.
isFile
(
phantom
.
casperScript
))
{
console
.
error
(
'Unable to open file: '
+
phantom
.
casperScript
);
return
phantom
.
exit
(
1
);
return
__die
(
'Unable to open file: '
+
phantom
.
casperScript
);
}
// filter out the called script name from casper args
...
...
@@ -255,10 +275,11 @@ CasperError.prototype = Object.getPrototypeOf(new Error());
initCasperCli
();
}
// casper loading status flag
phantom
.
casperLoaded
=
true
;
// passed casperjs script execution
if
(
!
phantom
.
injectJs
(
phantom
.
casperScript
))
{
throw
new
CasperError
(
'Unable to load script '
+
phantom
.
casperScript
+
'; check file syntax'
);
if
(
phantom
.
casperScript
&&
!
phantom
.
injectJs
(
phantom
.
casperScript
))
{
return
__die
(
'Unable to load script '
+
phantom
.
casperScript
+
'; check file syntax'
);
}
})(
window
,
phantom
);
...
...
bin/casperjs
View file @
3ca19ae
...
...
@@ -9,8 +9,11 @@ def test_cmd(cmd):
try
:
return
subprocess
.
check_output
([
__file__
]
+
cmd
.
split
(
' '
))
except
subprocess
.
CalledProcessError
as
err
:
sys
.
stderr
.
write
(
'FAIL:
%
s
\n
'
%
' '
.
join
(
err
.
cmd
))
sys
.
stderr
.
write
(
'
%
s
\n
'
%
err
.
output
)
sys
.
stderr
.
write
(
'FAIL:
%
s
\n
'
%
err
)
sys
.
stderr
.
write
(
' return code:
%
d
\n
'
%
err
.
returncode
)
sys
.
stderr
.
write
(
' args:
%
s
\n
'
%
','
.
join
(
err
.
args
))
sys
.
stderr
.
write
(
' cmd:
%
s
\n
'
%
' '
.
join
(
err
.
cmd
))
sys
.
stderr
.
write
(
' output:
%
s
\n
'
%
err
.
output
)
sys
.
exit
(
1
)
def
resolve
(
path
):
...
...
bin/usage.txt
View file @
3ca19ae
...
...
@@ -2,6 +2,7 @@
Usage: casperjs [options] script.[js|coffee] [script argument [script argument ...]]
casperjs [options] test [test path [test path ...]]
casperjs [options] selftest
casperjs [options] __selfcommandtest
Options:
...
...
Please
register
or
sign in
to post a comment