Merge pull request #356 from CosmWasm/add-arrayContentEquals

Add and use arrayContentEquals
This commit is contained in:
Ethan Frey 2020-08-07 11:24:48 +02:00 committed by GitHub
commit 2bf418f34a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 68 additions and 3 deletions

View File

@ -16,6 +16,7 @@
`BroadcastTxSuccess` and `BroadcastTxFailure` respectively, as well as helper
functions `isBroadcastTxFailure`, `isBroadcastTxSuccess` and
`assertIsBroadcastTxSuccess`.
- @cosmjs/utils: Add `arrayContentEquals`.
## 0.22.0 (2020-08-03)

View File

@ -4,7 +4,7 @@ import { Coin } from "@cosmjs/launchpad";
import { Uint64 } from "@cosmjs/math";
import * as proto from "@cosmjs/proto-signing";
import { Client as TendermintClient } from "@cosmjs/tendermint-rpc";
import { assertDefined } from "@cosmjs/utils";
import { arrayContentEquals, assertDefined } from "@cosmjs/utils";
import Long from "long";
import { BaseAccount } from "./query/accounts";
@ -118,8 +118,7 @@ export class StargateClient {
throw new Error(`Query failed with (${response.code}): ${response.log}`);
}
// TODO: better way to compare?
if (toHex(response.key) !== toHex(key)) {
if (!arrayContentEquals(response.key, key)) {
throw new Error(`Response key ${toHex(response.key)} doesn't match query key ${toHex(key)}`);
}

View File

@ -0,0 +1,33 @@
import { arrayContentEquals } from "./arrays";
describe("array", () => {
describe("arrayContentEquals", () => {
it("can compare number arrays", () => {
expect(arrayContentEquals([1, 2, 3], [1, 2, 3])).toEqual(true);
expect(arrayContentEquals([1, 2, 3], [1, 2, 3, 4])).toEqual(false);
expect(arrayContentEquals([1, 2, 3], [3, 2, 1])).toEqual(false);
});
it("can compare string arrays", () => {
expect(arrayContentEquals(["a", "b"], ["a", "b"])).toEqual(true);
expect(arrayContentEquals(["a", "b"], ["a", "b", "c"])).toEqual(false);
expect(arrayContentEquals(["a", "b"], ["b", "a"])).toEqual(false);
});
it("can compare bool arrays", () => {
expect(arrayContentEquals([true, false], [true, false])).toEqual(true);
expect(arrayContentEquals([true, false], [true, false, true])).toEqual(false);
expect(arrayContentEquals([true, false], [false, true])).toEqual(false);
});
it("can compare different array types", () => {
expect(arrayContentEquals([1, 2, 3], new Uint8Array([1, 2, 3]))).toEqual(true);
expect(arrayContentEquals([1, 2, 3], new Uint8Array([3, 2, 1]))).toEqual(false);
});
it("works for empty arrays", () => {
expect(arrayContentEquals([], [])).toEqual(true);
expect(arrayContentEquals([], new Uint8Array([]))).toEqual(true);
});
});
});

View File

@ -0,0 +1,18 @@
/**
* Compares the content of two arrays-like objects for equality.
*
* Equality is defined as having equal length and element values, where element equality means `===` returning `true`.
*
* This allows you to compare the content of a Buffer, Uint8Array or number[], ignoring the specific type.
* As a consequence, this returns different results than Jasmine's `toEqual`, which ensures elements have the same type.
*/
export function arrayContentEquals<T extends string | number | boolean>(
a: ArrayLike<T>,
b: ArrayLike<T>,
): boolean {
if (a.length !== b.length) return false;
for (let i = 0; i < a.length; ++i) {
if (a[i] !== b[i]) return false;
}
return true;
}

View File

@ -1,3 +1,4 @@
export { arrayContentEquals } from "./arrays";
export { assert, assertDefined } from "./assert";
export { sleep } from "./sleep";
export { isNonNullObject, isUint8Array } from "./typechecks";

12
packages/utils/types/arrays.d.ts vendored Normal file
View File

@ -0,0 +1,12 @@
/**
* Compares the content of two arrays-like objects for equality.
*
* Equality is defined as having equal length and element values, where element equality means `===` returning `true`.
*
* This allows you to compare the content of a Buffer, Uint8Array or number[], ignoring the specific type.
* As a consequence, this returns different results than Jasmine's `toEqual`, which ensures elements have the same type.
*/
export declare function arrayContentEquals<T extends string | number | boolean>(
a: ArrayLike<T>,
b: ArrayLike<T>,
): boolean;

View File

@ -1,3 +1,4 @@
export { arrayContentEquals } from "./arrays";
export { assert, assertDefined } from "./assert";
export { sleep } from "./sleep";
export { isNonNullObject, isUint8Array } from "./typechecks";