summaryrefslogtreecommitdiff
path: root/node_modules/needle/test/utils
diff options
context:
space:
mode:
author8cy <[email protected]>2020-04-03 02:37:42 -0700
committer8cy <[email protected]>2020-04-03 02:37:42 -0700
commit60867fb030bae582082340ead7dbc7efdc2f5398 (patch)
tree4c6a7356351be2e4914e15c4703172597c45656e /node_modules/needle/test/utils
parentcommenting (diff)
downloads5nical-60867fb030bae582082340ead7dbc7efdc2f5398.tar.xz
s5nical-60867fb030bae582082340ead7dbc7efdc2f5398.zip
2020/04/03, 02:34, v1.2.0
Diffstat (limited to 'node_modules/needle/test/utils')
-rw-r--r--node_modules/needle/test/utils/formidable.js17
-rw-r--r--node_modules/needle/test/utils/proxy.js62
-rw-r--r--node_modules/needle/test/utils/test.js104
3 files changed, 183 insertions, 0 deletions
diff --git a/node_modules/needle/test/utils/formidable.js b/node_modules/needle/test/utils/formidable.js
new file mode 100644
index 0000000..ba1d983
--- /dev/null
+++ b/node_modules/needle/test/utils/formidable.js
@@ -0,0 +1,17 @@
+var formidable = require('formidable'),
+ http = require('http'),
+ util = require('util');
+
+var port = process.argv[2] || 8888;
+
+http.createServer(function(req, res) {
+ var form = new formidable.IncomingForm();
+ form.parse(req, function(err, fields, files) {
+ res.writeHead(200, {'content-type': 'text/plain'});
+ res.write('received upload:\n\n');
+ console.log(util.inspect({fields: fields, files: files}))
+ res.end(util.inspect({fields: fields, files: files}));
+ });
+}).listen(port);
+
+console.log('HTTP server listening on port ' + port); \ No newline at end of file
diff --git a/node_modules/needle/test/utils/proxy.js b/node_modules/needle/test/utils/proxy.js
new file mode 100644
index 0000000..531bf49
--- /dev/null
+++ b/node_modules/needle/test/utils/proxy.js
@@ -0,0 +1,62 @@
+var http = require('http'),
+ https = require('https'),
+ url = require('url');
+
+var port = 1234,
+ log = true,
+ request_auth = false;
+
+http.createServer(function(request, response) {
+
+ console.log(request.headers);
+ console.log("Got request: " + request.url);
+ console.log("Forwarding request to " + request.headers['host']);
+
+ if (request_auth) {
+ if (!request.headers['proxy-authorization']) {
+ response.writeHead(407, {'Proxy-Authenticate': 'Basic realm="proxy.com"'})
+ return response.end('Hello.');
+ }
+ }
+
+ var remote = url.parse(request.url);
+ var protocol = remote.protocol == 'https:' ? https : http;
+
+ var opts = {
+ host: request.headers['host'],
+ port: remote.port || (remote.protocol == 'https:' ? 443 : 80),
+ method: request.method,
+ path: remote.pathname,
+ headers: request.headers
+ }
+
+ var proxy_request = protocol.request(opts, function(proxy_response){
+
+ proxy_response.on('data', function(chunk) {
+ if (log) console.log(chunk.toString());
+ response.write(chunk, 'binary');
+ });
+ proxy_response.on('end', function() {
+ response.end();
+ });
+
+ response.writeHead(proxy_response.statusCode, proxy_response.headers);
+ });
+
+ request.on('data', function(chunk) {
+ if (log) console.log(chunk.toString());
+ proxy_request.write(chunk, 'binary');
+ });
+
+ request.on('end', function() {
+ proxy_request.end();
+ });
+
+}).listen(port);
+
+process.on('uncaughtException', function(err){
+ console.log('Uncaught exception!');
+ console.log(err);
+});
+
+console.log("Proxy server listening on port " + port);
diff --git a/node_modules/needle/test/utils/test.js b/node_modules/needle/test/utils/test.js
new file mode 100644
index 0000000..8d58d70
--- /dev/null
+++ b/node_modules/needle/test/utils/test.js
@@ -0,0 +1,104 @@
+// TODO: write specs. :)
+
+var fs = require('fs'),
+ client = require('./../../');
+
+process.env.DEBUG = true;
+
+var response_callback = function(err, resp, body){
+ console.log(err);
+ if(resp) console.log("Got status code " + resp.statusCode)
+ console.log(body);
+}
+
+function simple_head(){
+ client.head('http://www.amazon.com', response_callback);
+}
+
+function simple_get(){
+ client.get('http://www.nodejs.org', response_callback);
+}
+
+function proxy_get(){
+ client.get('https://www.google.com/search?q=nodejs', {proxy: 'http://localhost:1234'}, response_callback);
+}
+
+function auth_get(){
+ client.get('https://www.twitter.com', {username: 'asd', password: '123'}, response_callback);
+}
+
+function simple_post(url){
+
+ var data = {
+ foo: 'bar',
+ baz: {
+ nested: 'attribute'
+ }
+ }
+
+ client.post(url, data, response_callback);
+
+}
+
+function multipart_post(url){
+
+ var filename = 'test_file.txt';
+ var data = 'Plain text data.\nLorem ipsum dolor sit amet.\nBla bla bla.\n';
+ fs.writeFileSync(filename, data);
+
+ var black_pixel = Buffer.from("data:image/gif;base64,R0lGODlhAQABAIAAAAUEBAAAACwAAAAAAQABAAACAkQBADs=".replace(/^data:image\/\w+;base64,/, ""), "base64");
+
+ var data = {
+ foo: 'bar',
+ bar: 'baz',
+ nested: {
+ my_document: { file: filename, content_type: 'text/plain' },
+ even: {
+ more: 'nesting'
+ }
+ },
+ pixel: { filename: 'black_pixel.gif', buffer: black_pixel, content_type: 'image/gif' },
+ field2: {value: JSON.stringify({"json":[ {"one":1}, {"two":2} ]}), content_type: 'application/json' }
+ }
+
+ client.post(url, data, {multipart: true}, function(err, resp, body){
+
+ console.log(err);
+ console.log("Got status code " + resp.statusCode)
+ console.log(body);
+ fs.unlink(filename);
+
+ });
+
+}
+
+switch(process.argv[2]){
+ case 'head':
+ simple_head();
+ break;
+ case 'get':
+ simple_get();
+ break;
+ case 'auth':
+ auth_get();
+ break;
+ case 'proxy':
+ proxy_get();
+ break;
+ case 'post':
+ simple_post(process.argv[3] || 'http://posttestserver.com/post.php');
+ break;
+ case 'multipart':
+ multipart_post(process.argv[3] || 'http://posttestserver.com/post.php?dir=example');
+ break;
+ case 'all':
+ simple_head();
+ simple_get();
+ auth_get();
+ proxy_get();
+ simple_post(process.argv[3] || 'http://posttestserver.com/post.php');
+ multipart_post(process.argv[3] || 'http://posttestserver.com/post.php?dir=example');
+ break;
+ default:
+ console.log("Usage: ./test.js [head|get|auth|proxy|multipart]")
+}