From 3ca8eb992e644d8eed6d007c9388ce8783add536 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=A1n=20Jakub=20Nani=C5=A1ta?= Date: Mon, 12 Feb 2024 15:03:50 -0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=A7=B9=20Add=20expect-based=20tests=20for?= =?UTF-8?q?=20interactive=20scripts=20(#389)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .eslintignore | 1 + .prettierignore | 1 + .../deploy-all-missing-tag.exp | 49 +++++++++++ .../deploy.test.expectations/deploy-all.exp | 48 +++++++++++ .../deploy-vengaboys-thrower.exp | 57 +++++++++++++ .../deploy-vengaboys.exp | 56 +++++++++++++ .../test/task/deploy.test.ts | 81 ++++++++++++++++++- 7 files changed, 292 insertions(+), 1 deletion(-) create mode 100755 tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-all-missing-tag.exp create mode 100755 tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-all.exp create mode 100755 tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-vengaboys-thrower.exp create mode 100755 tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-vengaboys.exp diff --git a/.eslintignore b/.eslintignore index 63f925619..1547e83f9 100644 --- a/.eslintignore +++ b/.eslintignore @@ -1,6 +1,7 @@ .turbo dist node_modules +*.exp *.md *.sol *.toml diff --git a/.prettierignore b/.prettierignore index 812d1748f..939d16551 100644 --- a/.prettierignore +++ b/.prettierignore @@ -1,3 +1,4 @@ +*.exp *.log .eslintignore .prettierignore diff --git a/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-all-missing-tag.exp b/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-all-missing-tag.exp new file mode 100755 index 000000000..fb6a05377 --- /dev/null +++ b/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-all-missing-tag.exp @@ -0,0 +1,49 @@ +#!/usr/bin/expect -f +# +# This Expect script was generated by autoexpect on Mon Feb 12 16:57:18 2024 +# Expect and autoexpect were both written by Don Libes, NIST. +# +# Note that autoexpect does not guarantee a working script. It +# necessarily has to guess about certain things. Two reasons a script +# might fail are: +# +# 1) timing - A surprising number of programs (rn, ksh, zsh, telnet, +# etc.) and devices discard or ignore keystrokes that arrive "too +# quickly" after prompts. If you find your new script hanging up at +# one spot, try adding a short sleep just before the previous send. +# Setting "force_conservative" to 1 (see below) makes Expect do this +# automatically - pausing briefly before sending each character. This +# pacifies every program I know of. The -c flag makes the script do +# this in the first place. The -C flag allows you to define a +# character to toggle this mode off and on. + +set force_conservative 0 +if {$force_conservative} { + set send_slow {1 .1} + proc send {ignore arg} { + sleep .1 + exp_send -s -- $arg + } +} + + +set timeout 60 +spawn npx hardhat lz:deploy +match_max 100000 + +expect "Which networks would you like to deploy?" +send -- "\r" + +expect "Which deploy script tags would you like to use?" +send -- "MeNoExist" +send -- "\r" + +expect "Will deploy 3 networks: britney, tango, vengaboys" +expect "Will use deploy scripts tagged with MeNoExist" +expect "Do you want to continue?" +send -- "\r" + +expect "Deploying..." +expect "Your contracts are now deployed" + +expect eof diff --git a/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-all.exp b/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-all.exp new file mode 100755 index 000000000..6d098aabc --- /dev/null +++ b/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-all.exp @@ -0,0 +1,48 @@ +#!/usr/bin/expect -f +# +# This Expect script was generated by autoexpect on Mon Feb 12 16:57:18 2024 +# Expect and autoexpect were both written by Don Libes, NIST. +# +# Note that autoexpect does not guarantee a working script. It +# necessarily has to guess about certain things. Two reasons a script +# might fail are: +# +# 1) timing - A surprising number of programs (rn, ksh, zsh, telnet, +# etc.) and devices discard or ignore keystrokes that arrive "too +# quickly" after prompts. If you find your new script hanging up at +# one spot, try adding a short sleep just before the previous send. +# Setting "force_conservative" to 1 (see below) makes Expect do this +# automatically - pausing briefly before sending each character. This +# pacifies every program I know of. The -c flag makes the script do +# this in the first place. The -C flag allows you to define a +# character to toggle this mode off and on. + +set force_conservative 0 +if {$force_conservative} { + set send_slow {1 .1} + proc send {ignore arg} { + sleep .1 + exp_send -s -- $arg + } +} + + +set timeout 60 +spawn npx hardhat lz:deploy +match_max 100000 + +expect "Which networks would you like to deploy?" +send -- "\r" + +expect "Which deploy script tags would you like to use?" +send -- "\r" + +expect "Will deploy 3 networks: britney, tango, vengaboys" +expect "Will use all deployment scripts" +expect "Do you want to continue?" +send -- "\r" + +expect "Deploying..." +expect "Your contracts are now deployed" + +expect eof diff --git a/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-vengaboys-thrower.exp b/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-vengaboys-thrower.exp new file mode 100755 index 000000000..19ef60a7c --- /dev/null +++ b/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-vengaboys-thrower.exp @@ -0,0 +1,57 @@ +#!/usr/bin/expect -f +# +# This Expect script was generated by autoexpect on Mon Feb 12 16:57:18 2024 +# Expect and autoexpect were both written by Don Libes, NIST. +# +# Note that autoexpect does not guarantee a working script. It +# necessarily has to guess about certain things. Two reasons a script +# might fail are: +# +# 1) timing - A surprising number of programs (rn, ksh, zsh, telnet, +# etc.) and devices discard or ignore keystrokes that arrive "too +# quickly" after prompts. If you find your new script hanging up at +# one spot, try adding a short sleep just before the previous send. +# Setting "force_conservative" to 1 (see below) makes Expect do this +# automatically - pausing briefly before sending each character. This +# pacifies every program I know of. The -c flag makes the script do +# this in the first place. The -C flag allows you to define a +# character to toggle this mode off and on. + +set force_conservative 0 +if {$force_conservative} { + set send_slow {1 .1} + proc send {ignore arg} { + sleep .1 + exp_send -s -- $arg + } +} + + +set timeout 60 +spawn npx hardhat lz:deploy +match_max 100000 + +expect "Which networks would you like to deploy?" + +# First we deselect britney +send -- " " +# We move down by pressing down array +send -- "\[B" +# Then we deselect tango +send -- " " +# Finally we confirm +send -- "\r" + +expect "Which deploy script tags would you like to use?" +send -- "Thrower" +send -- "\r" + +expect "Will deploy 1 network: vengaboys" +expect "Will use deploy scripts tagged with Thrower" +expect "Do you want to continue?" +send -- "\r" + +expect "Deploying..." +expect "Your contracts are now deployed" + +expect eof diff --git a/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-vengaboys.exp b/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-vengaboys.exp new file mode 100755 index 000000000..49c2666dc --- /dev/null +++ b/tests/devtools-evm-hardhat-test/test/task/deploy.test.expectations/deploy-vengaboys.exp @@ -0,0 +1,56 @@ +#!/usr/bin/expect -f +# +# This Expect script was generated by autoexpect on Mon Feb 12 16:57:18 2024 +# Expect and autoexpect were both written by Don Libes, NIST. +# +# Note that autoexpect does not guarantee a working script. It +# necessarily has to guess about certain things. Two reasons a script +# might fail are: +# +# 1) timing - A surprising number of programs (rn, ksh, zsh, telnet, +# etc.) and devices discard or ignore keystrokes that arrive "too +# quickly" after prompts. If you find your new script hanging up at +# one spot, try adding a short sleep just before the previous send. +# Setting "force_conservative" to 1 (see below) makes Expect do this +# automatically - pausing briefly before sending each character. This +# pacifies every program I know of. The -c flag makes the script do +# this in the first place. The -C flag allows you to define a +# character to toggle this mode off and on. + +set force_conservative 0 +if {$force_conservative} { + set send_slow {1 .1} + proc send {ignore arg} { + sleep .1 + exp_send -s -- $arg + } +} + + +set timeout 60 +spawn npx hardhat lz:deploy +match_max 100000 + +expect "Which networks would you like to deploy?" + +# First we deselect britney +send -- " " +# We move down by pressing down array +send -- "\[B" +# Then we deselect tango +send -- " " +# Finally we confirm +send -- "\r" + +expect "Which deploy script tags would you like to use?" +send -- "\r" + +expect "Will deploy 1 network: vengaboys" +expect "Will use all deployment scripts" +expect "Do you want to continue?" +send -- "\r" + +expect "Deploying..." +expect "Your contracts are now deployed" + +expect eof diff --git a/tests/devtools-evm-hardhat-test/test/task/deploy.test.ts b/tests/devtools-evm-hardhat-test/test/task/deploy.test.ts index d030f0629..86215800b 100644 --- a/tests/devtools-evm-hardhat-test/test/task/deploy.test.ts +++ b/tests/devtools-evm-hardhat-test/test/task/deploy.test.ts @@ -4,7 +4,15 @@ import hre from 'hardhat' import { TASK_COMPILE } from 'hardhat/builtin-tasks/task-names' import { DeploymentsManager } from 'hardhat-deploy/dist/src/DeploymentsManager' import { TASK_LZ_DEPLOY } from '@layerzerolabs/devtools-evm-hardhat' -import { promptForText, promptToContinue, promptToSelectMultiple } from '@layerzerolabs/io-devtools' +import { + isDirectory, + isFile, + promptForText, + promptToContinue, + promptToSelectMultiple, +} from '@layerzerolabs/io-devtools' +import { spawnSync } from 'child_process' +import { join } from 'path' jest.mock('@layerzerolabs/io-devtools', () => { const original = jest.requireActual('@layerzerolabs/io-devtools') @@ -24,6 +32,77 @@ const runSpy = jest.spyOn(hre, 'run') const runDeploySpy = jest.spyOn(DeploymentsManager.prototype, 'runDeploy') describe(`task ${TASK_LZ_DEPLOY}`, () => { + describe('expectations', () => { + const EXPECTATIONS_DIRECTORY = join('test', 'task', 'deploy.test.expectations') + const expectationPath = (name: string) => join(EXPECTATIONS_DIRECTORY, `${name}.exp`) + const runExpect = (name: string) => + spawnSync(expectationPath(name), { + encoding: 'utf8', + stdio: 'inherit', + }) + + const deploymentsPath = (networkName: string) => join('deployments', networkName) + + const deploymentPath = (networkName: string) => (name: string) => + join(deploymentsPath(networkName), `${name}.json`) + + it('should deploy all tags on all networks', async () => { + const result = runExpect('deploy-all') + + expect(result.status).toBe(0) + + const britneyDeploymentPath = deploymentPath('britney') + const tangoDeploymentPath = deploymentPath('tango') + const vengaboysDeploymentPath = deploymentPath('vengaboys') + + expect(isFile(britneyDeploymentPath('TestProxy'))).toBeTruthy() + expect(isFile(tangoDeploymentPath('TestProxy'))).toBeTruthy() + expect(isFile(vengaboysDeploymentPath('TestProxy'))).toBeTruthy() + + expect(isFile(britneyDeploymentPath('Thrower'))).toBeTruthy() + expect(isFile(tangoDeploymentPath('Thrower'))).toBeTruthy() + expect(isFile(vengaboysDeploymentPath('Thrower'))).toBeTruthy() + }) + + it('should deploy all tags on vengaboys', async () => { + const result = runExpect('deploy-vengaboys') + + expect(result.status).toBe(0) + + const vengaboysDeploymentPath = deploymentPath('vengaboys') + + expect(isDirectory(deploymentsPath('britney'))).toBeFalsy() + expect(isDirectory(deploymentsPath('tango'))).toBeFalsy() + + expect(isFile(vengaboysDeploymentPath('TestProxy'))).toBeTruthy() + expect(isFile(vengaboysDeploymentPath('Thrower'))).toBeTruthy() + }) + + it('should deploy single tag on vengaboys', async () => { + const result = runExpect('deploy-vengaboys-thrower') + + expect(result.status).toBe(0) + + const vengaboysDeploymentPath = deploymentPath('vengaboys') + + expect(isDirectory(deploymentsPath('britney'))).toBeFalsy() + expect(isDirectory(deploymentsPath('tango'))).toBeFalsy() + + expect(isFile(vengaboysDeploymentPath('Thrower'))).toBeTruthy() + expect(isFile(vengaboysDeploymentPath('TestProxy'))).toBeFalsy() + }) + + it('should not deploy anything if tag does not exist', async () => { + const result = runExpect('deploy-all-missing-tag') + + expect(result.status).toBe(0) + + expect(isDirectory(deploymentsPath('britney'))).toBeFalsy() + expect(isDirectory(deploymentsPath('tango'))).toBeFalsy() + expect(isDirectory(deploymentsPath('vengaboys'))).toBeFalsy() + }) + }) + const expectDeployment = expect.objectContaining({ abi: expect.any(Array), args: expect.any(Array),