mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
feat: allow comparing browser versions (#11954)
Co-authored-by: Nikolay Vitkov <34244704+Lightning00Blade@users.noreply.github.com>
This commit is contained in:
parent
73c1f9bbf3
commit
bf71b34fca
25
docs/browsers-api/browsers.getversioncomparator.md
Normal file
25
docs/browsers-api/browsers.getversioncomparator.md
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
---
|
||||||
|
sidebar_label: getVersionComparator
|
||||||
|
---
|
||||||
|
|
||||||
|
# getVersionComparator() function
|
||||||
|
|
||||||
|
Returns a version comparator for the given browser that can be used to sort browser versions.
|
||||||
|
|
||||||
|
#### Signature:
|
||||||
|
|
||||||
|
```typescript
|
||||||
|
export declare function getVersionComparator(
|
||||||
|
browser: Browser
|
||||||
|
): (a: string, b: string) => number;
|
||||||
|
```
|
||||||
|
|
||||||
|
## Parameters
|
||||||
|
|
||||||
|
| Parameter | Type | Description |
|
||||||
|
| --------- | -------------------------------- | ----------- |
|
||||||
|
| browser | [Browser](./browsers.browser.md) | |
|
||||||
|
|
||||||
|
**Returns:**
|
||||||
|
|
||||||
|
(a: string, b: string) => number
|
@ -50,20 +50,21 @@ The programmatic API allows installing and launching browsers from your code. Se
|
|||||||
|
|
||||||
## Functions
|
## Functions
|
||||||
|
|
||||||
| Function | Description |
|
| Function | Description |
|
||||||
| --------------------------------------------------------------------------------- | ----------------------------------------------------------------- |
|
| --------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------- |
|
||||||
| [canDownload(options)](./browsers.candownload.md) | |
|
| [canDownload(options)](./browsers.candownload.md) | |
|
||||||
| [computeExecutablePath(options)](./browsers.computeexecutablepath.md) | |
|
| [computeExecutablePath(options)](./browsers.computeexecutablepath.md) | |
|
||||||
| [computeSystemExecutablePath(options)](./browsers.computesystemexecutablepath.md) | |
|
| [computeSystemExecutablePath(options)](./browsers.computesystemexecutablepath.md) | |
|
||||||
| [createProfile(browser, opts)](./browsers.createprofile.md) | |
|
| [createProfile(browser, opts)](./browsers.createprofile.md) | |
|
||||||
| [detectBrowserPlatform()](./browsers.detectbrowserplatform.md) | |
|
| [detectBrowserPlatform()](./browsers.detectbrowserplatform.md) | |
|
||||||
| [getInstalledBrowsers(options)](./browsers.getinstalledbrowsers.md) | Returns metadata about browsers installed in the cache directory. |
|
| [getInstalledBrowsers(options)](./browsers.getinstalledbrowsers.md) | Returns metadata about browsers installed in the cache directory. |
|
||||||
| [install(options)](./browsers.install.md) | |
|
| [getVersionComparator(browser)](./browsers.getversioncomparator.md) | Returns a version comparator for the given browser that can be used to sort browser versions. |
|
||||||
| [install(options)](./browsers.install_1.md) | |
|
| [install(options)](./browsers.install.md) | |
|
||||||
| [launch(opts)](./browsers.launch.md) | |
|
| [install(options)](./browsers.install_1.md) | |
|
||||||
| [makeProgressCallback(browser, buildId)](./browsers.makeprogresscallback.md) | |
|
| [launch(opts)](./browsers.launch.md) | |
|
||||||
| [resolveBuildId(browser, platform, tag)](./browsers.resolvebuildid.md) | |
|
| [makeProgressCallback(browser, buildId)](./browsers.makeprogresscallback.md) | |
|
||||||
| [uninstall(options)](./browsers.uninstall.md) | |
|
| [resolveBuildId(browser, platform, tag)](./browsers.resolvebuildid.md) | |
|
||||||
|
| [uninstall(options)](./browsers.uninstall.md) | |
|
||||||
|
|
||||||
## Interfaces
|
## Interfaces
|
||||||
|
|
||||||
|
6
package-lock.json
generated
6
package-lock.json
generated
@ -6716,7 +6716,6 @@
|
|||||||
"version": "6.0.0",
|
"version": "6.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
|
||||||
"integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
|
"integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
|
||||||
"dev": true,
|
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"yallist": "^4.0.0"
|
"yallist": "^4.0.0"
|
||||||
},
|
},
|
||||||
@ -9163,7 +9162,6 @@
|
|||||||
"version": "7.6.0",
|
"version": "7.6.0",
|
||||||
"resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz",
|
"resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz",
|
||||||
"integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==",
|
"integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==",
|
||||||
"dev": true,
|
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"lru-cache": "^6.0.0"
|
"lru-cache": "^6.0.0"
|
||||||
},
|
},
|
||||||
@ -10953,8 +10951,7 @@
|
|||||||
"node_modules/yallist": {
|
"node_modules/yallist": {
|
||||||
"version": "4.0.0",
|
"version": "4.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
|
||||||
"integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
|
"integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="
|
||||||
"dev": true
|
|
||||||
},
|
},
|
||||||
"node_modules/yargs": {
|
"node_modules/yargs": {
|
||||||
"version": "16.2.0",
|
"version": "16.2.0",
|
||||||
@ -11083,6 +11080,7 @@
|
|||||||
"extract-zip": "2.0.1",
|
"extract-zip": "2.0.1",
|
||||||
"progress": "2.0.3",
|
"progress": "2.0.3",
|
||||||
"proxy-agent": "6.4.0",
|
"proxy-agent": "6.4.0",
|
||||||
|
"semver": "7.6.0",
|
||||||
"tar-fs": "3.0.5",
|
"tar-fs": "3.0.5",
|
||||||
"unbzip2-stream": "1.4.3",
|
"unbzip2-stream": "1.4.3",
|
||||||
"yargs": "17.7.2"
|
"yargs": "17.7.2"
|
||||||
|
@ -101,7 +101,8 @@
|
|||||||
"proxy-agent": "6.4.0",
|
"proxy-agent": "6.4.0",
|
||||||
"tar-fs": "3.0.5",
|
"tar-fs": "3.0.5",
|
||||||
"unbzip2-stream": "1.4.3",
|
"unbzip2-stream": "1.4.3",
|
||||||
"yargs": "17.7.2"
|
"yargs": "17.7.2",
|
||||||
|
"semver": "7.6.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/debug": "4.1.12",
|
"@types/debug": "4.1.12",
|
||||||
|
@ -43,6 +43,14 @@ export const executablePathByBrowser = {
|
|||||||
[Browser.FIREFOX]: firefox.relativeExecutablePath,
|
[Browser.FIREFOX]: firefox.relativeExecutablePath,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const versionComparators = {
|
||||||
|
[Browser.CHROMEDRIVER]: chromedriver.compareVersions,
|
||||||
|
[Browser.CHROMEHEADLESSSHELL]: chromeHeadlessShell.compareVersions,
|
||||||
|
[Browser.CHROME]: chrome.compareVersions,
|
||||||
|
[Browser.CHROMIUM]: chromium.compareVersions,
|
||||||
|
[Browser.FIREFOX]: firefox.compareVersions,
|
||||||
|
};
|
||||||
|
|
||||||
export {Browser, BrowserPlatform, ChromeReleaseChannel};
|
export {Browser, BrowserPlatform, ChromeReleaseChannel};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -185,3 +193,15 @@ export function resolveSystemExecutablePath(
|
|||||||
return chrome.resolveSystemExecutablePath(platform, channel);
|
return chrome.resolveSystemExecutablePath(platform, channel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a version comparator for the given browser that can be used to sort
|
||||||
|
* browser versions.
|
||||||
|
*
|
||||||
|
* @public
|
||||||
|
*/
|
||||||
|
export function getVersionComparator(
|
||||||
|
browser: Browser
|
||||||
|
): (a: string, b: string) => number {
|
||||||
|
return versionComparators[browser];
|
||||||
|
}
|
||||||
|
@ -66,4 +66,4 @@ export function relativeExecutablePath(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export {resolveBuildId} from './chrome.js';
|
export {resolveBuildId, compareVersions} from './chrome.js';
|
||||||
|
@ -6,6 +6,8 @@
|
|||||||
|
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
|
|
||||||
|
import semver from 'semver';
|
||||||
|
|
||||||
import {getJSON} from '../httpUtil.js';
|
import {getJSON} from '../httpUtil.js';
|
||||||
|
|
||||||
import {BrowserPlatform, ChromeReleaseChannel} from './types.js';
|
import {BrowserPlatform, ChromeReleaseChannel} from './types.js';
|
||||||
@ -193,3 +195,19 @@ export function resolveSystemExecutablePath(
|
|||||||
`Unable to detect browser executable path for '${channel}' on ${platform}.`
|
`Unable to detect browser executable path for '${channel}' on ${platform}.`
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function compareVersions(a: string, b: string): number {
|
||||||
|
if (!semver.valid(a)) {
|
||||||
|
throw new Error(`Version ${a} is not a valid semver version`);
|
||||||
|
}
|
||||||
|
if (!semver.valid(b)) {
|
||||||
|
throw new Error(`Version ${b} is not a valid semver version`);
|
||||||
|
}
|
||||||
|
if (semver.gt(a, b)) {
|
||||||
|
return 1;
|
||||||
|
} else if (semver.lt(a, b)) {
|
||||||
|
return -1;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -53,4 +53,4 @@ export function relativeExecutablePath(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export {resolveBuildId} from './chrome.js';
|
export {resolveBuildId, compareVersions} from './chrome.js';
|
||||||
|
@ -86,3 +86,7 @@ export async function resolveBuildId(
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function compareVersions(a: string, b: string): number {
|
||||||
|
return Number(a) - Number(b);
|
||||||
|
}
|
||||||
|
@ -328,3 +328,8 @@ async function writePreferences(options: ProfileOptions): Promise<void> {
|
|||||||
await fs.promises.copyFile(prefsPath, prefsBackupPath);
|
await fs.promises.copyFile(prefsPath, prefsBackupPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function compareVersions(a: string, b: string): number {
|
||||||
|
// TODO: this is a not very reliable check.
|
||||||
|
return parseInt(a.replace('.', ''), 16) - parseInt(b.replace('.', ''), 16);
|
||||||
|
}
|
||||||
|
@ -37,6 +37,7 @@ export {
|
|||||||
BrowserPlatform,
|
BrowserPlatform,
|
||||||
ChromeReleaseChannel,
|
ChromeReleaseChannel,
|
||||||
createProfile,
|
createProfile,
|
||||||
|
getVersionComparator,
|
||||||
} from './browser-data/browser-data.js';
|
} from './browser-data/browser-data.js';
|
||||||
export {CLI, makeProgressCallback} from './CLI.js';
|
export {CLI, makeProgressCallback} from './CLI.js';
|
||||||
export {Cache, InstalledBrowser} from './Cache.js';
|
export {Cache, InstalledBrowser} from './Cache.js';
|
||||||
|
@ -16,6 +16,7 @@ import {
|
|||||||
relativeExecutablePath,
|
relativeExecutablePath,
|
||||||
resolveSystemExecutablePath,
|
resolveSystemExecutablePath,
|
||||||
resolveBuildId,
|
resolveBuildId,
|
||||||
|
compareVersions,
|
||||||
} from '../../../lib/cjs/browser-data/chrome.js';
|
} from '../../../lib/cjs/browser-data/chrome.js';
|
||||||
|
|
||||||
describe('Chrome', () => {
|
describe('Chrome', () => {
|
||||||
@ -116,4 +117,10 @@ describe('Chrome', () => {
|
|||||||
it('should resolve build prefix', async () => {
|
it('should resolve build prefix', async () => {
|
||||||
assert.strictEqual(await resolveBuildId('115.0.5790'), '115.0.5790.170');
|
assert.strictEqual(await resolveBuildId('115.0.5790'), '115.0.5790.170');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should compare versions', async () => {
|
||||||
|
assert.ok(compareVersions('115.0.5790', '115.0.5789') >= 1);
|
||||||
|
assert.ok(compareVersions('115.0.5789', '115.0.5790') <= -1);
|
||||||
|
assert.ok(compareVersions('115.0.5790', '115.0.5790') === 0);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
@ -11,6 +11,7 @@ import {BrowserPlatform} from '../../../lib/cjs/browser-data/browser-data.js';
|
|||||||
import {
|
import {
|
||||||
resolveDownloadUrl,
|
resolveDownloadUrl,
|
||||||
relativeExecutablePath,
|
relativeExecutablePath,
|
||||||
|
compareVersions,
|
||||||
} from '../../../lib/cjs/browser-data/chromium.js';
|
} from '../../../lib/cjs/browser-data/chromium.js';
|
||||||
|
|
||||||
describe('Chromium', () => {
|
describe('Chromium', () => {
|
||||||
@ -59,4 +60,10 @@ describe('Chromium', () => {
|
|||||||
path.join('chrome-win', 'chrome.exe')
|
path.join('chrome-win', 'chrome.exe')
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should compare versions', async () => {
|
||||||
|
assert.ok(compareVersions('12372323', '12372322') >= 1);
|
||||||
|
assert.ok(compareVersions('12372322', '12372323') <= -1);
|
||||||
|
assert.ok(compareVersions('12372323', '12372323') === 0);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
@ -11,6 +11,7 @@ import path from 'path';
|
|||||||
|
|
||||||
import {BrowserPlatform} from '../../../lib/cjs/browser-data/browser-data.js';
|
import {BrowserPlatform} from '../../../lib/cjs/browser-data/browser-data.js';
|
||||||
import {
|
import {
|
||||||
|
compareVersions,
|
||||||
createProfile,
|
createProfile,
|
||||||
relativeExecutablePath,
|
relativeExecutablePath,
|
||||||
resolveDownloadUrl,
|
resolveDownloadUrl,
|
||||||
@ -94,4 +95,10 @@ describe('Firefox', () => {
|
|||||||
assert.ok(text.includes(`user_pref("test", 1);`)); // custom preference.
|
assert.ok(text.includes(`user_pref("test", 1);`)); // custom preference.
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should compare versions', async () => {
|
||||||
|
assert.ok(compareVersions('111.0a1', '110.0a1') >= 1);
|
||||||
|
assert.ok(compareVersions('110.0a1', '111.0a1') <= -1);
|
||||||
|
assert.ok(compareVersions('111.0a1', '111.0a1') === 0);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user