From 3958dde8114e4301c33a90073c1a2e3c973e0e5d Mon Sep 17 00:00:00 2001 From: Stan Bondi Date: Mon, 29 Aug 2022 13:34:25 +0400 Subject: [PATCH] fix(cucumber): handles listHeaders response correctly (#4551) Description --- - Fixes how listHeaders GRPC response is handled (since #4515) Motivation and Context --- #4515 returns the header in a nested struct, this PR updates the js code to handle that correctly. How Has This Been Tested? --- `Pruned node should prune outputs` passes --- .../features/support/node_steps.js | 10 +++---- integration_tests/helpers/baseNodeClient.js | 26 +++++++------------ 2 files changed, 15 insertions(+), 21 deletions(-) diff --git a/integration_tests/features/support/node_steps.js b/integration_tests/features/support/node_steps.js index e89e6e7f88..c5022cca00 100644 --- a/integration_tests/features/support/node_steps.js +++ b/integration_tests/features/support/node_steps.js @@ -363,18 +363,18 @@ Then( 5 * height /* 5 seconds per block */ ); const currTip = await client.getTipHeader(); - let currTipHeaderHeight = parseInt(currTip.header.height); + let currTipHeaderHeight = parseInt(currTip.height); console.log( - `${name} is at tip ${currTipHeaderHeight} (${currTip.header.hash.toString( + `${name} is at tip ${currTipHeaderHeight} (${currTip.hash.toString( "hex" )})` ); expect(currTipHeaderHeight).to.equal(height); if (!tipHash) { - tipHash = currTip.header.hash.toString("hex"); + tipHash = currTip.hash.toString("hex"); console.log(`Node ${name} is at tip: ${tipHash}`); } else { - const currTipHash = currTip.header.hash.toString("hex"); + const currTipHash = currTip.hash.toString("hex"); console.log( `Node ${name} is at tip: ${currTipHash} (should be ${tipHash})` ); @@ -506,7 +506,7 @@ Then(/node (.*) is at tip (.*)/, async function (node, name) { const existingHeader = this.headers[name]; expect(existingHeader).to.not.be.null; expect(existingHeader.header.hash.toString("hex")).to.equal( - header.header.hash.toString("hex") + header.hash.toString("hex") ); }); diff --git a/integration_tests/helpers/baseNodeClient.js b/integration_tests/helpers/baseNodeClient.js index 91ae8d8c4a..e7f55ad5aa 100644 --- a/integration_tests/helpers/baseNodeClient.js +++ b/integration_tests/helpers/baseNodeClient.js @@ -43,13 +43,9 @@ class BaseNodeClient { } getHeaderAt(height) { - return this.client - .listHeaders() - .sendMessage({ from_height: height, num_headers: 1 }) - .then((header) => { - console.log("Header:", header); - return header; - }); + return this.getHeaders(height, 1).then((header) => + header && header.length ? header[0].header : null + ); } getNetworkDifficulties(tip, start, end) { @@ -69,21 +65,19 @@ class BaseNodeClient { } getTipHeader() { - return this.client - .listHeaders() - .sendMessage({ from_height: 0, num_headers: 1 }) - .then((headers) => { - const header = headers[0]; - return Object.assign(header, { - height: +header.height, - }); + return this.getHeaders(0, 1).then((headers) => { + const header = headers[0].header; + return Object.assign(header, { + height: +header.height, }); + }); } async getHeaders(from_height, num_headers, sorting = 0) { return await this.client .listHeaders() - .sendMessage({ from_height, num_headers, sorting }); + .sendMessage({ from_height, num_headers, sorting }) + .then((resp) => resp.map((r) => r.header)); } getTipHeight() {