Compare commits

...

4 Commits

Author SHA1 Message Date
e955876a7c 2.0.2 2022-07-18 03:08:33 +02:00
b6472f38e2 fix(core): update 2022-07-18 03:08:32 +02:00
d4232decdd 2.0.1 2022-07-18 02:48:47 +02:00
76999d8720 fix(core): update 2022-07-18 02:48:46 +02:00
7 changed files with 2270 additions and 10734 deletions

12931
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -1,6 +1,6 @@
{ {
"name": "@pushrocks/smartpuppeteer", "name": "@pushrocks/smartpuppeteer",
"version": "2.0.0", "version": "2.0.2",
"private": false, "private": false,
"description": "simplified access to puppeteer", "description": "simplified access to puppeteer",
"main": "dist_ts/index.js", "main": "dist_ts/index.js",
@@ -13,17 +13,15 @@
"build": "tsbuild --web --allowimplicitany" "build": "tsbuild --web --allowimplicitany"
}, },
"devDependencies": { "devDependencies": {
"@gitzone/tsbuild": "^2.1.60", "@gitzone/tsbuild": "^2.1.63",
"@gitzone/tstest": "^1.0.69", "@gitzone/tstest": "^1.0.71",
"@pushrocks/tapbundle": "^5.0.3", "@pushrocks/tapbundle": "^5.0.3",
"@types/node": "^17.0.23", "@types/node": "^18.0.6"
"tslint": "^6.1.3",
"tslint-config-prettier": "^1.15.0"
}, },
"dependencies": { "dependencies": {
"@pushrocks/smartdelay": "^2.0.13", "@pushrocks/smartdelay": "^2.0.13",
"@pushrocks/smartshell": "^2.0.30", "@pushrocks/smartshell": "^2.0.30",
"puppeteer": "^13.5.1", "puppeteer": "^15.4.0",
"tree-kill": "^1.2.2" "tree-kill": "^1.2.2"
}, },
"files": [ "files": [

View File

@@ -1,11 +1,26 @@
import { expect, tap } from '@pushrocks/tapbundle'; import { expect, tap } from '@pushrocks/tapbundle';
import * as smartpuppeteer from '../ts/index.js'; import * as smartpuppeteer from '../ts/index.js';
tap.test('first test', async (tools) => { tap.test('should use pipe', async (tools) => {
const headlessBrowser = await smartpuppeteer.getEnvAwareBrowserInstance({ const headlessBrowser = await smartpuppeteer.getEnvAwareBrowserInstance({
forceNoSandbox: true, forceNoSandbox: false,
}); });
const page = await headlessBrowser.newPage(); const page = await headlessBrowser.newPage();
await page.goto('https://lossless.com');
console.log(await page.title());
expect(headlessBrowser.wsEndpoint()).toEqual('');
await headlessBrowser.close();
});
tap.test('should use websocket', async (tools) => {
const headlessBrowser = await smartpuppeteer.getEnvAwareBrowserInstance({
forceNoSandbox: false,
usePipe: false,
});
const page = await headlessBrowser.newPage();
await page.goto('https://lossless.com');
console.log(await page.title());
expect(headlessBrowser.wsEndpoint()).not.toEqual('');
await headlessBrowser.close(); await headlessBrowser.close();
}); });

8
ts/00_commitinfo_data.ts Normal file
View File

@@ -0,0 +1,8 @@
/**
* autocreated commitinfo by @pushrocks/commitinfo
*/
export const commitinfo = {
name: '@pushrocks/smartpuppeteer',
version: '2.0.2',
description: 'simplified access to puppeteer'
}

View File

@@ -28,7 +28,7 @@ export class IncognitoBrowser {
*/ */
public async stop() { public async stop() {
this.status = 'stopped'; this.status = 'stopped';
plugins.treeKill(this.browser.process().pid, 'SIGKILL'); plugins.treeKill(this.browser.process()?.pid as number, 'SIGKILL');
await this.browser.close(); await this.browser.close();
} }

View File

@@ -2,6 +2,7 @@ import * as plugins from './smartpuppeteer.plugins.js';
export interface IEnvAwareOptions { export interface IEnvAwareOptions {
forceNoSandbox?: boolean; forceNoSandbox?: boolean;
usePipe?: boolean;
} }
export const getEnvAwareBrowserInstance = async ( export const getEnvAwareBrowserInstance = async (
@@ -24,7 +25,7 @@ export const getEnvAwareBrowserInstance = async (
console.log(chromeArgs); console.log(chromeArgs);
headlessBrowser = await plugins.puppeteer.launch({ headlessBrowser = await plugins.puppeteer.launch({
args: chromeArgs, args: chromeArgs,
pipe: true, pipe: options.usePipe !== undefined ? options.usePipe : true,
headless: true, headless: true,
...(() => { ...(() => {
const returnObject: any = {}; const returnObject: any = {};

View File

@@ -1,17 +0,0 @@
{
"extends": ["tslint:latest", "tslint-config-prettier"],
"rules": {
"semicolon": [true, "always"],
"no-console": false,
"ordered-imports": false,
"object-literal-sort-keys": false,
"member-ordering": {
"options":{
"order": [
"static-method"
]
}
}
},
"defaultSeverity": "warning"
}