Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Bots navigating urls and doing tasks.
damon
is a CLI that runs on CasperJS which runs on PhantomJS.
He feeds on JSON files that describe what tasks he needs to achieve on specified starting URL.
Usage:
damon [OPTIONS] [COMMAND]
Commands:
run <files...> Run the list of JSON tasks files. Accept glob.
Options:
-h, --help output usage information
-V, --version output the version number
via NPM :
# Locally
npm install --save damon
# Globally
npm install -g damon
var damon = require('damon');
damon.start('./tasks.json');
> damon run tasks.json
or
> damon run tasks1.json tasks2.json
or
> damon run *.json
config
Your task file must have a config
entry with a size
and a url
.
"config": {
"size": {
"width": 1024,
"height": 768
},
"url": "http://www.google.ca",
"timeout": 1000,
"logLevel": "fatal",
"describe": "This is a job description"
}
size
is for the viewport's size.url
is the starting point of damon
.timeout
overwrite the general timeout used accross the test suite.logLevel
control at which level damon
will log. Can be none
, fatal
, error
, warn
, info
, debug
or trace
describe
is used to give a description of the job. It is printed next to the filename in the default reporter.tasks
Then you describe your tasks in a tasks
entry that is an array of all the tasks to achieve sequentially :
"tasks": [
{},
{}
]
Each task will have three components:
{
"type": "taskType",
"it": "should run this task",
"params": {}
}
type
give the type of task for damon
to run.params
provide arguments to be passed to the task.it
provide a description of the task, to be printed on the default reporter (optional).It exists several kinds of tasks that damon
can achieve :
capture
A simple screen capture :
{
"type": "capture",
"params": {
"name": "start.png"
}
}
download
Download the target url
{
"type": "download",
"params": {
"url": "http://www.google.com",
"name": "google.html",
"method": "GET",
"data": ""
}
}
An HTTP method can be set with method
, and pass request arguments through data
.
wait
damon
can wait for several different things.
For each one, except time
, you can overwrite the timeout
.
url
{
"type": "wait",
"params": {
"url": "http://www.yahoo.ca",
"regexp": false,
"timeout": 1000
}
}
damon
will wait at this step until matching url is reached.
url
will be interpreted as a regexp
if set to true
. Default value of regexp
is false
.
selector
{
"type": "wait",
"params": {
"selector": "#content",
"timeout": 1000,
"xpath": false
}
}
damon
will wait at this step until the selector
is available on the page.
xpath
can be used to select an element by setting it to true. Default value is false.
visible
hidden
Both are the same as selector
but will wait for these specific states of the element.
time
{
"type": "wait",
"params": {
"time": "1000"
}
}
damon
will wait for the specified amount of milliseconds.
resource
{
"type": "wait",
"params": {
"resource": "resourceName",
"regexp": false,
"timeout": 1000,
"method": "DELETE"
}
}
damon
will wait at this step until something matching the resource is received.
resource
will be interpreted as a regexp
if set to true
. Default value of regexp
is false
.
A method
can be specified to filter the resource. If nothing is specified, any method
will be accepted.
dom
damon
can perform two different actions on a dom element :
click
{
"type": "dom",
"params": {
"selector": "button#btnSubmit",
"xpath": false,
"do": "click",
}
}
damon
will click on the specified selector.
fill
{
"type": "dom",
"params": {
"selector": "input#userName",
"xpath": false,
"do": "fill",
"text": "yoann.dev"
}
}
damon
will enter text in the specified field.
xpath
cannot be used when filling a file field due to PhantomJS limitiations.
get
damon
can perform different get
to retrieve a value and store it for subsequent tasks :
attribute
{
"type": "get",
"params": {
"selector": "div#Info",
"xpath": false,
"attribute": "title",
"key": "infoTitle",
"modifier": "[a-z]+"
}
}
damon
will get the value of the attribute
, apply the modifier
RegExp and store it as infoTitle
.
@text
can also be used as an attribute
to get the text content of the selector
variable
{
"type": "get",
"params": {
"variable": "var.attr1['attr2']",
"key": "varAttr2"
}
}
damon
will access to the specified variable with window
as the root object and store its value as varAttr2
resource
{
"type": "get",
"params": {
"resource": "resourceLink",
"regexp": false,
"variable": "payload.title",
"key": "title",
"method": "POST"
}
}
damon
will access to the specified variable of the matching resource
and store it.
A method
can be specified to filter the resource. If nothing is specified, any method
will be accepted.
To access to a variable in the payload of a resource, write payload.variableName
for variable
field. Resource also contains the headers
, method
, time
and url
.
number of elements
{
"type": "get",
"params": {
"selector": "ul#list li",
"xpath": false,
"key": "liNumber"
}
}
damon
will store the number of elements that satisfy the selector
The value can then be accessed in any following tasks via its key
value
{
"type": "wait",
"params": {
"url": "http://www.yahoo.ca/{{key}}"
}
}
To access the stored value, call the key
in between double brackets {{key}}
request
damon
can perform an AJAX call from within its workflow.
{
"type": "request",
"params": {
"url": "https://www.google.com",
"method": "GET",
"payload": {
"q": "funny cats"
},
"headers": {
"header": "value"
},
"store": {
"key": "key",
"variable": "variable.attr1"
}
}
}
You can also store
the response for later use with {{key}}
.
If you don't pass a variable
it will store the complete response.
Otherwise, it will try to parse the response as JSON and look for your variable.
assert
damon
can perform different assert
actions to test a value with an expected value:
{
"type": "assert",
"params": {
"selector": "div#Info",
"xpath": false,
"attribute": "title",
"modifier": "[a-z]+",
"expected": "expectedValue or {{key}}"
}
}
damon
will get
the value of the attribute
and test it against the expected
value or the value associated with {{key}}
{
"type": "assert",
"params": {
"variable": "var.attr1['attr2']",
"expected": "expectedValue or {{key}}"
}
}
damon
will get
the value of the variable
and test it against the expected
value or the value associated with {{key}}
{
"type": "assert",
"params": {
"key": "title",
"expected": "Expected Title"
}
}
damon
will get
the value of the key
and test it against the expected
value.
{
"type": "assert",
"params": {
"url": "url",
"https": false,
"expected": 200
}
}
damon
will try to make a GET
request on the url
and test the request status against the expected
status. Same-origin policy applies.
https
flag can be set to false
to replace https
in the url
by http
.
We welcome Your interest in Autodesk’s Open Source Damon (the “Project”).
Any Contributor to the Project must accept and sign an Agreement indicating agreement to the license terms below.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
FAQs
Bot navigating urls and doing tasks.
The npm package damon receives a total of 32 weekly downloads. As such, damon popularity was classified as not popular.
We found that damon demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.