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
c287c823
...
c287c823b2cad41a369178a7d0f4e6ff0a08c279
authored
2012-12-07 12:24:59 +0100
by
Nicolas Perriault
Browse Files
Options
Browse Files
Tag
Download
Email Patches
Plain Diff
refs #279 - added module (still WiP)
1 parent
9b9fb4b3
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
116 additions
and
8 deletions
modules/casper.js
modules/page.js
modules/casper.js
View file @
c287c82
...
...
@@ -35,6 +35,7 @@ var events = require('events');
var
fs
=
require
(
'fs'
);
var
http
=
require
(
'http'
);
var
mouse
=
require
(
'mouse'
);
var
casperpage
=
require
(
'page'
);
var
qs
=
require
(
'querystring'
);
var
tester
=
require
(
'tester'
);
var
utils
=
require
(
'utils'
);
...
...
@@ -120,6 +121,7 @@ var Casper = function Casper(options) {
this
.
options
=
utils
.
mergeObjects
(
this
.
defaults
,
options
);
// properties
this
.
checker
=
null
;
this
.
childPages
=
new
casperpage
.
ChildPages
();
this
.
cli
=
phantom
.
casperArgs
;
this
.
colorizer
=
this
.
getColorizer
();
this
.
currentResponse
=
undefined
;
...
...
@@ -138,7 +140,6 @@ var Casper = function Casper(options) {
};
this
.
mouse
=
mouse
.
create
(
this
);
this
.
page
=
null
;
this
.
childPages
=
[];
this
.
pendingWait
=
false
;
this
.
requestUrl
=
'about:blank'
;
this
.
resources
=
[];
...
...
@@ -1865,17 +1866,13 @@ Casper.prototype.waitWhileVisible = function waitWhileVisible(selector, then, on
* Makes the provided child page as the currently active one. Note that the
* active page will be reverted when finished.
*
* @param
WebPage childPage A child page instance
* @param
String|RegExp|WebPage childPageInfo Target child page information
* @param Function then Next step function
* @return Casper
*/
Casper
.
prototype
.
withChildPage
=
function
withChildPage
(
childPage
,
then
)
{
Casper
.
prototype
.
withChildPage
=
function
withChildPage
(
childPage
Info
,
then
)
{
"use strict"
;
if
(
!
utils
.
isWebPage
(
childPage
)
||
!
this
.
childPages
.
some
(
function
(
activePage
)
{
return
activePage
.
id
===
childPage
.
id
;
}))
{
throw
new
CasperError
(
"withChildPage() invalid or missing child page."
);
}
var
childPage
=
this
.
childPages
.
find
(
childPageInfo
);
if
(
!
utils
.
isFunction
(
then
))
{
throw
new
CasperError
(
"withChildPage() requires a step function."
);
}
...
...
modules/page.js
0 → 100644
View file @
c287c82
/*!
* Casper is a navigation utility for PhantomJS.
*
* Documentation: http://casperjs.org/
* Repository: http://github.com/n1k0/casperjs
*
* Copyright (c) 2011-2012 Nicolas Perriault
*
* Part of source code is Copyright Joyent, Inc. and other Node contributors.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
* DEALINGS IN THE SOFTWARE.
*
*/
/*global CasperError console exports phantom require*/
var
utils
=
require
(
'utils'
);
var
f
=
utils
.
format
;
/**
* Child pages container. Implements Array prototype.
*
*/
var
ChildPages
=
function
ChildPages
(){};
exports
.
ChildPages
=
ChildPages
;
ChildPages
.
prototype
=
[];
/**
* Finds a child page matching the provided information. Information can be:
*
* - RegExp: matching page url
* - String: strict page url value
* - WebPage: a direct WebPage instance
*
* @param Mixed pageInfo
* @return WebPage
*/
ChildPages
.
prototype
.
find
=
function
find
(
pageInfo
)
{
"use strict"
;
var
childPage
,
type
=
utils
.
betterTypeOf
(
pageInfo
);
switch
(
type
)
{
case
"regexp"
:
childPage
=
this
.
findByRegExp
(
pageInfo
);
break
;
case
"string"
:
childPage
=
this
.
findByURL
(
pageInfo
);
break
;
case
"qtruntimeobject"
:
// WebPage
childPage
=
pageInfo
;
if
(
!
utils
.
isWebPage
(
childPage
)
||
!
this
.
some
(
function
(
activePage
)
{
return
activePage
.
id
===
childPage
.
id
;
}))
{
throw
new
CasperError
(
"Invalid or missing child page."
);
}
break
;
default
:
throw
new
CasperError
(
f
(
"Invalid pageInfo type: %s."
,
type
));
}
return
childPage
;
};
/**
* Finds the first child page which url matches a given RegExp.
*
* @param RegExp regexp
* @return WebPage
*/
ChildPages
.
prototype
.
findByRegExp
=
function
findByRegExp
(
regexp
)
{
"use strict"
;
var
childPage
=
this
.
filter
(
function
(
activePage
)
{
return
regexp
.
test
(
activePage
.
url
);
})[
0
];
if
(
!
childPage
)
{
throw
new
CasperError
(
f
(
"Couldn't find child page with url matching pattern %s"
,
regexp
));
}
return
childPage
;
};
/**
* Finds the first child page matching a given url.
*
* @param String url The child WebPage url
* @return WebPage
*/
ChildPages
.
prototype
.
findByURL
=
function
findByURL
(
url
)
{
"use strict"
;
var
childPage
=
this
.
filter
(
function
(
activePage
)
{
return
activePage
.
url
===
url
;
})[
0
];
if
(
!
childPage
)
{
throw
new
CasperError
(
f
(
"Couldn't find child page with url %s"
,
url
));
}
return
childPage
;
};
Please
register
or
sign in
to post a comment