Add libtool version comparison module and tests
This commit is contained in:
parent
4d70795c98
commit
55a1b25ea2
30
src/libtoolVersion-test.ts
Normal file
30
src/libtoolVersion-test.ts
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
/*
|
||||||
|
This file is part of TALER
|
||||||
|
(C) 2017 GNUnet e.V.
|
||||||
|
|
||||||
|
TALER is free software; you can redistribute it and/or modify it under the
|
||||||
|
terms of the GNU General Public License as published by the Free Software
|
||||||
|
Foundation; either version 3, or (at your option) any later version.
|
||||||
|
|
||||||
|
TALER is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||||
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
||||||
|
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License along with
|
||||||
|
TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
|
||||||
|
*/
|
||||||
|
|
||||||
|
import * as LibtoolVersion from "./libtoolVersion";
|
||||||
|
|
||||||
|
import {test} from "ava";
|
||||||
|
|
||||||
|
test("version comparison", (t) => {
|
||||||
|
t.deepEqual(LibtoolVersion.compare("0:0:0", "0:0:0"), {compatible: true, currentCmp: 0});
|
||||||
|
t.deepEqual(LibtoolVersion.compare("0:0:0", ""), undefined);
|
||||||
|
t.deepEqual(LibtoolVersion.compare("foo", "0:0:0"), undefined);
|
||||||
|
t.deepEqual(LibtoolVersion.compare("0:0:0", "1:0:1"), {compatible: true, currentCmp: -1});
|
||||||
|
t.deepEqual(LibtoolVersion.compare("0:0:0", "1:5:1"), {compatible: true, currentCmp: -1});
|
||||||
|
t.deepEqual(LibtoolVersion.compare("0:0:0", "1:5:0"), {compatible: false, currentCmp: -1});
|
||||||
|
t.deepEqual(LibtoolVersion.compare("1:0:0", "0:5:0"), {compatible: false, currentCmp: 1});
|
||||||
|
t.deepEqual(LibtoolVersion.compare("1:0:1", "1:5:1"), {compatible: true, currentCmp: 0});
|
||||||
|
});
|
83
src/libtoolVersion.ts
Normal file
83
src/libtoolVersion.ts
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
/*
|
||||||
|
This file is part of TALER
|
||||||
|
(C) 2017 GNUnet e.V.
|
||||||
|
|
||||||
|
TALER is free software; you can redistribute it and/or modify it under the
|
||||||
|
terms of the GNU General Public License as published by the Free Software
|
||||||
|
Foundation; either version 3, or (at your option) any later version.
|
||||||
|
|
||||||
|
TALER is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||||
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
||||||
|
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License along with
|
||||||
|
TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Semantic versioning, but libtool-style.
|
||||||
|
* See https://www.gnu.org/software/libtool/manual/html_node/Libtool-versioning.html
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Result of comparing two libtool versions.
|
||||||
|
*/
|
||||||
|
export interface VersionMatchResult {
|
||||||
|
/**
|
||||||
|
* Is the first version compatible with the second?
|
||||||
|
*/
|
||||||
|
compatible: boolean;
|
||||||
|
/**
|
||||||
|
* Is the first version older (-1), newser (+1) or
|
||||||
|
* identical (0)?
|
||||||
|
*/
|
||||||
|
currentCmp: number
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Version {
|
||||||
|
current: number;
|
||||||
|
revision: number;
|
||||||
|
age: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function compare(me: string, other: string): VersionMatchResult|undefined {
|
||||||
|
const meVer = parseVersion(me);
|
||||||
|
const otherVer = parseVersion(other);
|
||||||
|
|
||||||
|
if (!(meVer && otherVer)) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
const compatible = (meVer.current <= otherVer.current &&
|
||||||
|
meVer.current >= (otherVer.current - otherVer.age));
|
||||||
|
|
||||||
|
const currentCmp = Math.sign(meVer.current - otherVer.current);
|
||||||
|
|
||||||
|
return {compatible, currentCmp};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function parseVersion(v: string): Version|undefined {
|
||||||
|
const [currentStr, revisionStr, ageStr, ...rest] = v.split(":");
|
||||||
|
if (rest.length != 0) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
const current = Number.parseInt(currentStr);
|
||||||
|
const revision = Number.parseInt(revisionStr);
|
||||||
|
const age = Number.parseInt(ageStr);
|
||||||
|
|
||||||
|
if (Number.isNaN(current)) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Number.isNaN(revision)) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Number.isNaN(age)) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
return {current, revision, age};
|
||||||
|
}
|
@ -321,7 +321,7 @@ export interface ConfigRecord {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
const WALLET_PROTOCOL_VERSION = "0:0:0";
|
export const WALLET_PROTOCOL_VERSION = "0:0:0";
|
||||||
|
|
||||||
const builtinCurrencies: CurrencyRecord[] = [
|
const builtinCurrencies: CurrencyRecord[] = [
|
||||||
{
|
{
|
||||||
|
@ -39,6 +39,8 @@
|
|||||||
"src/http.ts",
|
"src/http.ts",
|
||||||
"src/i18n.tsx",
|
"src/i18n.tsx",
|
||||||
"src/i18n/strings.ts",
|
"src/i18n/strings.ts",
|
||||||
|
"src/libtoolVersion-test.ts",
|
||||||
|
"src/libtoolVersion.ts",
|
||||||
"src/logging.ts",
|
"src/logging.ts",
|
||||||
"src/memidb-test.ts",
|
"src/memidb-test.ts",
|
||||||
"src/memidb.ts",
|
"src/memidb.ts",
|
||||||
|
Loading…
Reference in New Issue
Block a user