fix(ci): remove ci dependencies
This commit is contained in:
		| @@ -3,9 +3,7 @@ | ||||
|     "coverageTreshold": 50 | ||||
|   }, | ||||
|   "npmci": { | ||||
|     "npmGlobalTools": [ | ||||
|       "npmts" | ||||
|     ], | ||||
|     "npmGlobalTools": [], | ||||
|     "npmAccessLevel": "public" | ||||
|   } | ||||
| } | ||||
| @@ -34,4 +34,4 @@ | ||||
|     "@pushrocks/tapbundle": "^3.0.5", | ||||
|     "@types/node": "^10.5.8" | ||||
|   } | ||||
| } | ||||
| } | ||||
							
								
								
									
										17
									
								
								test/test.ts
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								test/test.ts
									
									
									
									
									
								
							| @@ -23,17 +23,18 @@ tap.test('should post a JSON document over http', async () => { | ||||
| }); | ||||
|  | ||||
| tap.skip.test('should deal with unix socks', async () => { | ||||
|   const socketResponse = await smartrequest.request('http://unix:/var/run/docker.sock:/containers/json', { | ||||
|     headers: { | ||||
|       "Content-Type": "application/json", | ||||
|       "Host": "docker.sock" | ||||
|   const socketResponse = await smartrequest.request( | ||||
|     'http://unix:/var/run/docker.sock:/containers/json', | ||||
|     { | ||||
|       headers: { | ||||
|         'Content-Type': 'application/json', | ||||
|         Host: 'docker.sock' | ||||
|       } | ||||
|     } | ||||
|   }); | ||||
|   ); | ||||
|   console.log(socketResponse.body); | ||||
| }); | ||||
|  | ||||
| tap.skip.test('should correctly upload a file using formData', async () => { | ||||
|    | ||||
| }) | ||||
| tap.skip.test('should correctly upload a file using formData', async () => {}); | ||||
|  | ||||
| tap.start(); | ||||
|   | ||||
| @@ -1,25 +1,20 @@ | ||||
| import * as plugins from "./smartrequest.plugins"; | ||||
| import * as interfaces from "./smartrequest.interfaces"; | ||||
| import { request } from "./smartrequest.request"; | ||||
| import * as plugins from './smartrequest.plugins'; | ||||
| import * as interfaces from './smartrequest.interfaces'; | ||||
| import { request } from './smartrequest.request'; | ||||
|  | ||||
| /** | ||||
|  * the interfae for FormFieldData | ||||
|  */ | ||||
| export interface IFormField { | ||||
|   name: string; | ||||
|   type: "string" | "filePath" | "Buffer"; | ||||
|   type: 'string' | 'filePath' | 'Buffer'; | ||||
|   payload: string; | ||||
| } | ||||
|  | ||||
| const appendFormField = async ( | ||||
|   formDataArg: plugins.formData, | ||||
|   formDataField: IFormField | ||||
| ) => { | ||||
|   if (formDataField.type === "filePath") { | ||||
|     let fileData = plugins.fs.readFileSync( | ||||
|       plugins.path.join(process.cwd(), formDataField.payload) | ||||
|     ); | ||||
|     formDataArg.append("file", fileData, { | ||||
| const appendFormField = async (formDataArg: plugins.formData, formDataField: IFormField) => { | ||||
|   if (formDataField.type === 'filePath') { | ||||
|     let fileData = plugins.fs.readFileSync(plugins.path.join(process.cwd(), formDataField.payload)); | ||||
|     formDataArg.append('file', fileData, { | ||||
|       filename: 'upload.pdf', | ||||
|       contentType: 'application/pdf' | ||||
|     }); | ||||
| @@ -38,7 +33,7 @@ export const postFormData = async ( | ||||
|   const requestOptions = Object.assign({}, optionsArg, { | ||||
|     method: 'POST', | ||||
|     headers: { | ||||
|       ...(optionsArg.headers), | ||||
|       ...optionsArg.headers, | ||||
|       ...form.getHeaders() | ||||
|     }, | ||||
|     requestBody: form | ||||
|   | ||||
| @@ -7,4 +7,4 @@ import * as url from 'url'; | ||||
|  | ||||
| import * as smartpromise from '@pushrocks/smartpromise'; | ||||
|  | ||||
| export {formData, http, https, fs, path, url, smartpromise }; | ||||
| export { formData, http, https, fs, path, url, smartpromise }; | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| import * as https from "https"; | ||||
| import * as plugins from "./smartrequest.plugins"; | ||||
| import * as interfaces from "./smartrequest.interfaces"; | ||||
| import * as https from 'https'; | ||||
| import * as plugins from './smartrequest.plugins'; | ||||
| import * as interfaces from './smartrequest.interfaces'; | ||||
|  | ||||
| import { IncomingMessage } from "http"; | ||||
| import { IncomingMessage } from 'http'; | ||||
|  | ||||
| export interface IExtendedIncomingMessage extends IncomingMessage { | ||||
|   body: any; | ||||
| @@ -13,12 +13,12 @@ const buildUtf8Response = ( | ||||
| ): Promise<IExtendedIncomingMessage> => { | ||||
|   let done = plugins.smartpromise.defer<IExtendedIncomingMessage>(); | ||||
|   // Continuously update stream with data | ||||
|   let body = ""; | ||||
|   incomingMessageArg.on("data", function(chunkArg) { | ||||
|   let body = ''; | ||||
|   incomingMessageArg.on('data', function(chunkArg) { | ||||
|     body += chunkArg; | ||||
|   }); | ||||
|  | ||||
|   incomingMessageArg.on("end", function() { | ||||
|   incomingMessageArg.on('end', function() { | ||||
|     try { | ||||
|       (incomingMessageArg as IExtendedIncomingMessage).body = JSON.parse(body); | ||||
|     } catch (err) { | ||||
| @@ -47,8 +47,8 @@ const parseSocketPathAndRoute = (stringToParseArg: string) => { | ||||
|   return { | ||||
|     socketPath: result[1], | ||||
|     path: result[2] | ||||
|   } | ||||
| } | ||||
|   }; | ||||
| }; | ||||
|  | ||||
| export let request = async ( | ||||
|   domainArg: string, | ||||
| @@ -67,31 +67,30 @@ export let request = async ( | ||||
|   optionsArg.path = parsedUrl.path; | ||||
|  | ||||
|   // determine if unixsock | ||||
|   if(testForUnixSock(domainArg)) { | ||||
|     const detailedUnixPath = parseSocketPathAndRoute(optionsArg.path) | ||||
|   if (testForUnixSock(domainArg)) { | ||||
|     const detailedUnixPath = parseSocketPathAndRoute(optionsArg.path); | ||||
|     optionsArg.socketPath = detailedUnixPath.socketPath; | ||||
|     optionsArg.path = detailedUnixPath.path; | ||||
|   } | ||||
|    | ||||
|  | ||||
|   // lets determine the request module to use | ||||
|   const requestModule = (() => { | ||||
|     if (parsedUrl.protocol === "https:") { | ||||
|     if (parsedUrl.protocol === 'https:') { | ||||
|       return plugins.https; | ||||
|     } else if (parsedUrl.protocol === "http:") { | ||||
|     } else if (parsedUrl.protocol === 'http:') { | ||||
|       return plugins.http; | ||||
|     } else { | ||||
|       throw new Error(`unsupported protocol: ${parsedUrl.protocol}`); | ||||
|     } | ||||
|   })() as typeof plugins.https; | ||||
|  | ||||
|  | ||||
|   // lets perform the actual request | ||||
|   let request = requestModule.request(optionsArg); | ||||
|  | ||||
|   // lets write the requestBody | ||||
|   if (optionsArg.requestBody) { | ||||
|     if (!(optionsArg.requestBody instanceof plugins.formData)) { | ||||
|       if(typeof optionsArg.requestBody !== "string") { | ||||
|       if (typeof optionsArg.requestBody !== 'string') { | ||||
|         optionsArg.requestBody = JSON.stringify(optionsArg.requestBody); | ||||
|       } | ||||
|       request.write(optionsArg.requestBody); | ||||
| @@ -106,16 +105,16 @@ export let request = async ( | ||||
|   } | ||||
|  | ||||
|   // lets handle an error | ||||
|   request.on("error", e => { | ||||
|   request.on('error', e => { | ||||
|     console.error(e); | ||||
|   }); | ||||
|  | ||||
|   // lets handle the response | ||||
|   request.on("response", async response => { | ||||
|   request.on('response', async response => { | ||||
|     if (streamArg) { | ||||
|       done.resolve(response); | ||||
|     } else { | ||||
|       const builtResponse = await buildUtf8Response(response) | ||||
|       const builtResponse = await buildUtf8Response(response); | ||||
|       done.resolve(builtResponse); | ||||
|     } | ||||
|   }); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user