Skip to content

Commit 5b65279

Browse files
authored
Merge pull request #4 from max-ostapenko/rich-platypus
Pull the Wappalyzer config for a single test
2 parents b55f6b7 + a521b5e commit 5b65279

11 files changed

+147
-130
lines changed

README.md

+16-54
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@
33

44
# WebPageTest API Wrapper for NodeJS
55

6-
[![Build Status](https://travis-ci.com/WebPageTest/webpagetest-api.svg?branch=master)](https://travis-ci.com/WebPageTest/webpagetest-api)
6+
<!-- [![Build Status](https://travis-ci.com/WebPageTest/webpagetest-api.svg?branch=master)](https://travis-ci.com/WebPageTest/webpagetest-api) -->
77
[![NPM Version](https://img.shields.io/npm/v/webpagetest.svg?style=flat)](https://www.npmjs.org/package/webpagetest)
88
[![NPM Downloads](https://img.shields.io/npm/dm/webpagetest.svg?style=flat)](https://www.npmjs.org/package/webpagetest)
99

@@ -22,7 +22,7 @@ npm install webpagetest -g
2222
### Command line
2323

2424
```bash
25-
webpagetest test https://docs.webpagetest.org/api/integrations/
25+
webpagetest test https://docs.webpagetest.org/api/integrations/ -k YOURAPIKEY
2626
```
2727

2828
### Docker
@@ -98,6 +98,7 @@ webpagetest --help
9898
- **-s, --server** _\<server\>_: the WPT server URL [https://www.webpagetest.org]
9999
- **-d, --dryrun**: just return the RESTful API URL
100100
- **-o, --out** _\<file\>_: place the output into \<file\>. Defaults to stdout
101+
- **--http_method** _\<method\>_: the HTTP method to use (GET, POST) [GET]
101102

102103
_The default WPT server can also be specified via environment variable `WEBPAGETEST_SERVER`_
103104

@@ -139,6 +140,7 @@ _The default WPT server can also be specified via environment variable `WEBPAGET
139140
- **-b, --block** _\<urls\>_: space-delimited list of urls to block (substring match)
140141
- **-Z, --spof** _\<domains\>_: space-delimited list of domains to simulate failure by re-routing to blackhole.webpagetest.org to silently drop all requests
141142
- **-c, --custom** _\<script\>_: execute arbitrary javascript at the end of a test to collect custom metrics
143+
- **-w, --wappalyzerpr** _\<number\>_: set the wappalyzer fork PR number to use for technology detection
142144
- **-a, --authtype** _\<type\>_: type of authentication: 0 = Basic, 1 = SNS [0]
143145
- **-n, --notify** _\<e-mail\>_: e-mail address to notify with the test results
144146
- **-B, --pingback** _\<url\>_: URL to ping when the test is complete (the test ID will be passed as an "id" parameter)
@@ -239,10 +241,10 @@ _The default WPT server can also be specified via environment variable `WEBPAGET
239241

240242
### Examples
241243

242-
#### 1. Get all available locations
244+
#### 1. Get API available locations
243245

244246
```bash
245-
$ webpagetest locations
247+
$ webpagetest locations -k YOURAPIKEY
246248
```
247249

248250
```javascript
@@ -270,41 +272,10 @@ $ webpagetest locations
270272
}
271273
```
272274

273-
#### 2. Get API available locations
275+
#### 2. Run test on https://docs.webpagetest.org/api/integrations/ from San Jose on IE9
274276

275277
```bash
276-
webpagetest locations --key 1F2A3K4E5
277-
```
278-
279-
```javascript
280-
{
281-
"response": {
282-
"statusCode": 200, "statusText": "Ok",
283-
"data": {
284-
"location": [
285-
...
286-
{
287-
"id": "SanJose_IE9",
288-
"Label": "San Jose, CA USA (IE 9,Chrome,Firefox)",
289-
"location": "SanJose_IE9",
290-
"Browser": "IE 9",
291-
"PendingTests": {
292-
"p1": 0, "p2": 0, "p3": 0, "p4": 0, "p5": 2, "p6": 2, "p7": 0,
293-
"p8": 0, "p9": 0, "Total": 7, "HighPriority": 2, "LowPriority": 4,
294-
"Testing": 1, "Idle": 0
295-
}
296-
},
297-
...
298-
]
299-
}
300-
}
301-
}
302-
```
303-
304-
#### 3. Run test on https://docs.webpagetest.org/api/integrations/ from San Jose on IE9
305-
306-
```bash
307-
webpagetest test https://docs.webpagetest.org/api/integrations/ --key 1F2A3K4E5 --location SanJose_IE9
278+
webpagetest test https://docs.webpagetest.org/api/integrations/ -k YOURAPIKEY --location SanJose_IE9
308279
```
309280

310281
```javascript
@@ -323,10 +294,10 @@ webpagetest test https://docs.webpagetest.org/api/integrations/ --key 1F2A3K4E5
323294
}
324295
```
325296

326-
#### 4. Check current test status
297+
#### 3. Check current test status
327298

328299
```bash
329-
webpagetest status 121025_PT_N8K
300+
webpagetest status 121025_PT_N8K -k YOURAPIKEY
330301
```
331302

332303
```javascript
@@ -344,10 +315,10 @@ webpagetest status 121025_PT_N8K
344315
}
345316
```
346317

347-
#### 5. Get test results
318+
#### 4. Get test results
348319

349320
```bash
350-
webpagetest results 121025_PT_N8K
321+
webpagetest results 121025_PT_N8K -k YOURAPIKEY
351322
```
352323

353324
```javascript
@@ -379,23 +350,12 @@ webpagetest results 121025_PT_N8K
379350
}
380351
```
381352

382-
#### 6. Get test waterfall thumbnail from repeat view as data URI
383-
384-
```bash
385-
webpagetest waterfall 121025_PT_N8K --thumbnail --cached --uri
386-
```
387353

388-
```javascript
389-
{
390-
"type": "image/png",
391-
"data": "iVBORw0KGgoAAAANSUhEUgA...RK5CYII="
392-
}
393-
```
394354

395-
#### 7. Get remaining tests count for the account
355+
#### 5. Get remaining tests count for the account
396356

397357
```bash
398-
webpagetest testBalance --key 1F2A3K4E5
358+
webpagetest testBalance -k YOURAPIKEY
399359
```
400360

401361
```javascript
@@ -522,6 +482,7 @@ wpt.runTest(script, (err, data) => {
522482

523483
- **dryRun**: _Boolean_, if `true`, method does not make an actual request to the API Server but rather returns an object with `url` which contains the actual URL to make the GET request to WebPageTest API Server
524484
- **server**: _String_, if specified, overrides the WebPageTest server informed in the constructor only for that method call
485+
- **http_method**: _String_, if specified, overrides the HTTP method in the constructor only for that method call (GET, POST) [GET]
525486

526487
#### Test (works with `runTest` and `runTestAndWait`)
527488

@@ -559,6 +520,7 @@ wpt.runTest(script, (err, data) => {
559520
- **block**: _String_, space-delimited list of urls to block (substring match)
560521
- **spof**: _String_, space-delimited list of domains to simulate failure by re-routing to blackhole.webpagetest.org to silently drop all requests
561522
- **customMetrics**: _String_, execute arbitrary JavaScript at the end of a test to collect custom metrics
523+
- **wappalyzerpr** _Integer_, set the wappalyzer fork PR number to use for technology detection
562524
- **authenticationType**: _Number_, type of authentication: 0 = Basic, 1 = SNS [0]
563525
- **notifyEmail**: _String_, e-mail address to notify with the test results
564526
- **pingback**: _String_, URL to ping when the test is complete (the test ID will be passed as an "id" parameter)

bin/webpagetest

+3-1
Original file line numberDiff line numberDiff line change
@@ -269,14 +269,16 @@ function cleanupProgram() {
269269
delete program.server;
270270
delete program.dryrun;
271271
delete program.out;
272+
delete program.http_method;
272273
}
273274

274275
function execCommand() {
275-
var wpt = new WebPageTest(program.server || defaultServer);
276+
var wpt = new WebPageTest(program.server || defaultServer, options.key);
276277

277278
// options
278279
if (options) {
279280
options.dryRun = program.dryrun;
281+
options.http_method = program.http_method;
280282
args.push(options);
281283
}
282284

lib/helper.js

+33-33
Original file line numberDiff line numberDiff line change
@@ -5,25 +5,25 @@
55
* Released under the MIT License
66
*/
77

8-
var xml2js = require('xml2js'),
9-
url = require('url'),
10-
os = require('os'),
11-
csv = require('csv'),
12-
entities = require('entities'),
13-
qs = require('querystring');
8+
var xml2js = require('xml2js'),
9+
url = require('url'),
10+
os = require('os'),
11+
csv = require('csv'),
12+
entities = require('entities')
13+
qs = require('querystring');
1414

15-
var parser = new xml2js.Parser({ explicitArray: false, mergeAttrs: true });
15+
var parser = new xml2js.Parser({explicitArray: false, mergeAttrs: true});
1616

1717
var reNumber = /^[\.\+\-]?[\d\.]+$/,
18-
reInvalidDec = /(?:\.\d*){2,}/,
19-
reDec = /\./,
20-
reLineBreak = /[\n\r]+/g,
21-
reLastBreak = /\n$/,
22-
reProtocol = /^https?:\/\//i,
23-
reIp = /\d+\.\d+\.\d+\.\d+/, // 127.0.0.1
18+
reInvalidDec = /(?:\.\d*){2,}/,
19+
reDec = /\./,
20+
reLineBreak = /[\n\r]+/g,
21+
reLastBreak = /\n$/,
22+
reProtocol = /^https?:\/\//i,
23+
reIp = /\d+\.\d+\.\d+\.\d+/, // 127.0.0.1
2424

25-
TAB = '\t',
26-
NEWLINE = '\n';
25+
TAB = '\t',
26+
NEWLINE = '\n';
2727

2828
function parseNumber(s) {
2929
if (typeof s !== 'string' || !reNumber.test(s) || reInvalidDec.test(s)) {
@@ -35,7 +35,7 @@ function parseNumber(s) {
3535

3636
function normalizeObj(root) {
3737
if (typeof root === 'object') {
38-
Object.keys(root).forEach(function (key) {
38+
Object.keys(root).forEach(function(key) {
3939
var value = root[key];
4040
if (typeof value === 'string') {
4141
if (value.length === 0 || value === '\n') {
@@ -63,8 +63,8 @@ function xmlToObj(xml, callback) {
6363

6464
function svToObj(delimiter, headers, sv) {
6565
var data,
66-
start = 0,
67-
obj = {};
66+
start = 0,
67+
obj = {};
6868

6969
delimiter = delimiter || ',';
7070

@@ -102,11 +102,11 @@ function svToObj(delimiter, headers, sv) {
102102
}
103103

104104
function csvParser(data, callback) {
105-
csv.parse(data.toString(), { columns: true }, function (err, data) {
105+
csv.parse(data.toString(), { columns: true }, function(err, data) {
106106
if (err) {
107107
callback.bind(this, err);
108108
}
109-
csv.transform(data, function (row) {
109+
csv.transform(data, function(row) {
110110
var key, value;
111111
for (key in row) {
112112
value = row[key].replace(/<b>|<\/b>/g, '');
@@ -170,18 +170,18 @@ function dryRun(config, path, form) {
170170
}),
171171
form: qs.stringify(form)
172172
};
173-
} else {
174-
return {
175-
url: url.format({
176-
protocol: config.protocol,
177-
hostname: config.hostname,
178-
port: (config.port !== 80 && config.port !== 443 ?
179-
config.port : undefined),
180-
pathname: path.pathname,
181-
query: path.query
182-
})
183-
};
184173
}
174+
175+
return {
176+
url: url.format({
177+
protocol: config.protocol,
178+
hostname: config.hostname,
179+
port: (config.port !== 80 && config.port !== 443 ?
180+
config.port : undefined),
181+
pathname: path.pathname,
182+
query: path.query
183+
})
184+
};
185185
}
186186

187187
// Normalize server config
@@ -235,8 +235,8 @@ function setQuery(map, options, query) {
235235
map.options.forEach(function eachOpts(opt) {
236236
Object.keys(opt).forEach(function eachOpt(key) {
237237
var param = opt[key],
238-
name = param.name,
239-
value = options[name] || options[key];
238+
name = param.name,
239+
value = options[name] || options[key];
240240

241241
if (value !== undefined && param.api) {
242242
if (param.array) {

0 commit comments

Comments
 (0)