diff --git a/.github/workflows/build-linux-appimage.yml b/.github/workflows/build-linux-appimage.yml index 4ebb3bf0..55c0ae81 100644 --- a/.github/workflows/build-linux-appimage.yml +++ b/.github/workflows/build-linux-appimage.yml @@ -19,7 +19,7 @@ jobs: - name: Install node uses: actions/setup-node@v3 with: - node-version: 18 + node-version: "20.10.0" - name: Variables helpers id: setup @@ -64,7 +64,7 @@ jobs: - name: Upload artifacts uses: actions/upload-artifact@v3 - #if: ${{ github.ref_name == 'main' }} + if: ${{ github.ref_name == 'main' }} with: name: ${{ runner.os }}-${{ steps.setup.outputs.app-name }}-AppImage retention-days: 5 diff --git a/.github/workflows/build-linux-deb.yml b/.github/workflows/build-linux-deb.yml new file mode 100644 index 00000000..3c01d68c --- /dev/null +++ b/.github/workflows/build-linux-deb.yml @@ -0,0 +1,73 @@ +name: Build electron application as deb package on linux + +on: + workflow_call: + secrets: + token: + required: true + +jobs: + + build-linux: + runs-on: ubuntu-latest + + steps: + + - name: Checkout Git repository + uses: actions/checkout@v3 + + - name: Install node + uses: actions/setup-node@v3 + with: + node-version: "20.10.0" + + - name: Variables helpers + id: setup + run: | + KRUX_VERSION=`node -e "console.log(require('./package.json').version)"` + echo "app-version=$KRUX_VERSION" >> $GITHUB_OUTPUT + KRUX_NAME=krux-installer + echo "app-name=${KRUX_NAME}_${KRUX_VERSION}_amd64" >> $GITHUB_OUTPUT + echo "::group::Variables" + echo "app-version=$KRUX_VERSION" + echo "app-name=$KRUX_NAME" + echo "::endgroup::" + + - name: Install dependencies + run: yarn install + + - name: Build electron app + env: + GH_TOKEN: ${{ secrets.token }} + run: yarn run build --linux deb + + - name: Hash electron app (Linux) + uses: qlrd/sha256sum-action@v2 + with: + working-directory: ./release/${{ steps.setup.outputs.app-version }} + file: ${{ steps.setup.outputs.app-name }}.deb + ext: sha256.txt + + - name: List release files + run: | + echo "::group::Release files" + ls -la release/${{ steps.setup.outputs.app-version }} + echo "::endgroup::" + + - name: Install xvfb-maybe to allow headless test + run: yarn add --dev xvfb-maybe + + - name: E2E test electron app + env: + DEBUG: 'krux:*' + run: ./node_modules/.bin/xvfb-maybe ./node_modules/.bin/wdio run wdio.conf.mts + + - name: Upload artifacts + uses: actions/upload-artifact@v3 + if: ${{ github.ref_name == 'main' }} + with: + name: ${{ runner.os }}-${{ steps.setup.outputs.app-name }}-deb + retention-days: 5 + path: | + release/${{ steps.setup.outputs.app-version }}/${{ steps.setup.outputs.app-name }}.deb + release/${{ steps.setup.outputs.app-version }}/${{ steps.setup.outputs.app-name }}.deb.sha256.txt diff --git a/.github/workflows/build-mac-dmg.yml b/.github/workflows/build-mac-dmg.yml index cb787ddb..9a3e13e9 100644 --- a/.github/workflows/build-mac-dmg.yml +++ b/.github/workflows/build-mac-dmg.yml @@ -19,7 +19,7 @@ jobs: - name: Install node uses: actions/setup-node@v3 with: - node-version: 18 + node-version: "20.10.0" - name: Variables helpers id: setup diff --git a/.github/workflows/build-windows-nsis.yml b/.github/workflows/build-windows-nsis.yml index 6566d9db..ae38686d 100644 --- a/.github/workflows/build-windows-nsis.yml +++ b/.github/workflows/build-windows-nsis.yml @@ -17,19 +17,19 @@ jobs: - name: Install node uses: actions/setup-node@v3 with: - node-version: 18 + node-version: "20.10.0" - name: Variables helpers id: setup shell: pwsh run: | $loc = Get-Location - $firmware_version = "v23.09.0" + $firmware_version = "v23.09.1" $zipname = "krux-$firmware_version.zip" $signame = "krux-$firmware_version.zip.sig" $pemname = "selfcustody.pem" $extraResources = "$loc\extraResources" - $opensslVersion = "3.1.3" + $opensslVersion = "3.2.0" $release_url = "https://github.com/selfcustody/krux/releases/download" $raw_url = "https://raw.githubusercontent.com/selfcustody/krux/main" $app_version = node -e "console.log(require('./package.json').version)" @@ -128,7 +128,7 @@ jobs: - name: Install chromedriver.exe shell: pwsh run: | - $url = "https://chromedriver.storage.googleapis.com/106.0.5249.61/chromedriver_win32.zip" + $url = "https://edgedl.me.gvt1.com/edgedl/chrome/chrome-for-testing/120.0.6099.56/win32/chrome-win32.zip" $tmp_path = ".\chromedriver_win32.zip" $dest_path = "node_modules\chromedriver\bin" Invoke-WebRequest -Uri $url -OutFile $tmp_path @@ -169,7 +169,7 @@ jobs: - name: Upload artifacts uses: actions/upload-artifact@v3 - #if: ${{ github.ref_name == 'main' }} + if: ${{ github.ref_name == 'main' }} with: name: ${{ runner.os}}-${{ steps.setup.outputs.app-name }}-Nsis retention-days: 5 diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 6547efba..a57a4156 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -11,7 +11,7 @@ on: - ".vscode" - ".dockerignore" - "Dockerfile" - #- ".gitignore" + - ".gitignore" #- ".github/**" #- "!.github/workflows/build.yml" @@ -22,12 +22,17 @@ jobs: secrets: token: ${{ secrets.github_token }} - build-windows-nsis: - uses: ./.github/workflows/build-windows-nsis.yml + build-linux-deb: + uses: ./.github/workflows/build-linux-deb.yml secrets: token: ${{ secrets.github_token }} - build-mac-dmg: - uses: ./.github/workflows/build-mac-dmg.yml + build-windows-nsis: + uses: ./.github/workflows/build-windows-nsis.yml secrets: token: ${{ secrets.github_token }} + + #build-mac-dmg: + # uses: ./.github/workflows/build-mac-dmg.yml + # secrets: + # token: ${{ secrets.github_token }} diff --git a/.vscode/.e2e.env b/.vscode/.e2e.env index d2cc6e73..1a3ca42b 100644 --- a/.vscode/.e2e.env +++ b/.vscode/.e2e.env @@ -1 +1,2 @@ -DEBUG=krux:* \ No newline at end of file +DEBUG=krux:* +NODE_ENV=test \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md index db6dbaa1..0efb829c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,33 +1,27 @@ -## 2022-10-03 +# 0.0.1 -[v2.1.0](https://github.com/electron-vite/electron-vite-vue/pull/267) +- Major updates dependencies: + - `electron`: 28.1.0; + - `vite-plugin-electron`: 0.15.5; + - `wdio-electron-service`: 6.0.2. -- `vite-electron-plugin` is Fast, and WYSIWYG. 🌱 -- last-commit: db2e830 v2.1.0: use `vite-electron-plugin` instead `vite-plugin-electron` +- Minor updates: + - `@wdio/cli`: 8.27.0; + - `@wdio/globals`: 8.27.0; + - `@wdio/local-runner`: 8.27.0; + - `@wdio/mocha-framework`: 8.27.0; + - `@wdio/spec-reporter`: 8.27.0; + - `vue`: 3.3.13; + - `vue-tsc`: 1.8.26; + - `vuetify`: 3.4.8; -## 2022-06-04 +- Refactored `test/e2e/specs`: + - to suit `wdio-electron-service` major updates that break E2E tests; + - renamed extensions to `mts` to suit `vite-plugin-electron`; + - updated krux firmware version checks to `23.09.1`; -[v2.0.0](https://github.com/electron-vite/electron-vite-vue/pull/156) +- Updated `openssl` for windows to `3.2.0` *; -- 🖖 Based on the `vue-ts` template created by `npm create vite`, integrate `vite-plugin-electron` -- ⚡️ More simplify, is in line with Vite project structure -- last-commit: a15028a (HEAD -> main) feat: hoist `process.env` +- Removed MacOS release since the current approach did not worked well on MacOS; -## 2022-01-30 - -[v1.0.0](https://github.com/electron-vite/electron-vite-vue/releases/tag/v1.0.0) - -- ⚡️ Main、Renderer、preload, all built with vite - -## 2022-01-27 -- Refactor the scripts part. -- Remove `configs` directory. - -## 2021-11-11 -- Refactor the project. Use vite.config.ts build `Main-process`, `Preload-script` and `Renderer-process` alternative rollup. -- Scenic `Vue>=3.2.13`, `@vue/compiler-sfc` is no longer necessary. -- If you prefer Rollup, Use rollup branch. - -```bash -Error: @vitejs/plugin-vue requires vue (>=3.2.13) or @vue/compiler-sfc to be present in the dependency tree. -``` +> \* see [WARNING](WARNING.md) diff --git a/README.md b/README.md index 69afc0a7..045ff520 100644 --- a/README.md +++ b/README.md @@ -22,8 +22,6 @@ For more information, see [flash the firmware onto the device](https://selfcusto - MacOS -**Help Wanted**: we need mac users! - ## Install - See [releases page](https://github.com/selfcustody/krux-installer/releases); @@ -102,6 +100,13 @@ if you want to show some debug messages: DEBUG=krux:* yarn run dev ``` +#### Debug development app with VSCode/VSCodium + +If you're codding with VSCode/VSCodium, go to `Run and Debug` +tab and select `Debug App`: + +![VScodium Debug](images/vscodium_debug.png) + ### Test #### Prepare tests @@ -159,81 +164,18 @@ In linux/mac: DEBUG=krux:* yarn run build -- ``` -##### Filter tests - -Additionaly, you can filter some tests with -`--filter` option and a based regular expression argument. +##### Run tests -For example, if you want to exclude tests until `25th` test, -you can do this: +To run all tests in command line: ```bash -yarn run e2e --filter '0([0-1][0-9]|2[0-4]).*.spec.ts' +NODE_ENV=test yarn run e2e ``` -if you want to debug some messages: +#### Debug test in VSCode/VSCodium -```bash -DEBUG=krux:* yarn run e2e --filter '0([0-1][0-9]|2[0-4]).*.spec.ts' -``` +If you're codding with VSCode/VSCodium, the `NODE_ENV` +variable is already configured. To run, tests, go to `Run and Debug` +tab and select `Test E2E App`: -#### WARNING: Builtin OpenSSL for windows in KruxInstaller - -When downloading official krux firmware versions, -it is necessary to verify the signature through the OpenSSL tool, -as a way to verify the authenticity of the downloaded binaries. - -On "Unix like" releases (Linux and MacOS), -verification is easily done since such tool -exists natively in operating system. - -In windows release, -we are faced with the peculiarity of the operating system in question -do not have such a tool -(see this [issue](https://github.com/qlrd/krux-installer/issues/2)). - -So, we packaged a stable version of OpenSSL, and -compiled it from the [source](https://github.com/openssl/openssl). -The compilation process is done entirely in a reproducible virtual environment and, -therefore, not locally, with the github-action [compile-openssl-windows-action](https://github.com/qlrd/compile-openssl-windows-action/actions). - -Since it is compiled in a virtual environment on github: - -- it is expected to be fully verifiable and free of malicious code; -- it is expected that, if you're developing in Windows machine, -some difficulties will be appear. -- You can check the build steps in [actions](https://github.com/qlrd/krux-installer/actions). - -## TODOs - -- Kendryte K210 devices: - - [x] Flash to M5stickV; - - [x] Flash to Sipeed Amigo; - - [x] Flash to Sipeed Bit; - - [x] Flash to Sipeed Dock; - - [ ] Flash to Yahboom Aimotion - - [ ] Build from source to M5stickV; - - [ ] Build from source to Sipeed Amigo; - - [ ] Build from source to Sipeed Bit; - - [ ] Build from source to Sipeed Dock; - - [ ] Debug for M5stickV; - - [ ] Debug for Sipeed Amigo; - - [ ] Debug for Sipeed Bit; - - [ ] Debug for Sipeed Dock; -- [odudex Android version](https://github.com/odudex/krux_binaries/tree/main/Android): - - [ ] Transfer to device; - - [ ] Build for device; - - [ ] Debug for device. -- Windows: - - [x] Build NSIS installer; - - [ ] Build Portable installer; - - [ ] Build AppX installer; -- Linux: - - [x] Build `AppImage` standalone; - - [ ] Build `deb` package for [apt-get](https://www.debian.org/doc/manuals/apt-howto/); - - [ ] Build `snap` package for [snapcraft](https://snapcraft.io/); - - [ ] Build `pacman` package for [pacman](https://wiki.archlinux.org/title/Pacman). -- MacOS: - - [x] Build DMG installer; - - [ ] Build PKG installer; - - [ ] Build MAS installer; +![VScodium E2E test](images/vscodium.png) diff --git a/TODO.md b/TODO.md new file mode 100644 index 00000000..aab660fe --- /dev/null +++ b/TODO.md @@ -0,0 +1,33 @@ +# TODO + +- Kendryte K210 devices: + - [x] Flash to M5stickV; + - [x] Flash to Sipeed Amigo; + - [x] Flash to Sipeed Bit; + - [x] Flash to Sipeed Dock; + - [ ] Flash to Yahboom Aimotion + - [ ] Build from source to M5stickV; + - [ ] Build from source to Sipeed Amigo; + - [ ] Build from source to Sipeed Bit; + - [ ] Build from source to Sipeed Dock; + - [ ] Debug for M5stickV; + - [ ] Debug for Sipeed Amigo; + - [ ] Debug for Sipeed Bit; + - [ ] Debug for Sipeed Dock; +- [odudex Android version](https://github.com/odudex/krux_binaries/tree/main/Android): + - [ ] Transfer to device; + - [ ] Build for device; + - [ ] Debug for device. +- Windows: + - [x] Build NSIS installer; + - [ ] Build Portable installer; + - [ ] Build AppX installer; +- Linux: + - [x] Build `AppImage` standalone; + - [x] Build `deb` package for [apt-get](https://www.debian.org/doc/manuals/apt-howto/); + - [ ] Build `snap` package for [snapcraft](https://snapcraft.io/); + - [ ] Build `pacman` package for [pacman](https://wiki.archlinux.org/title/Pacman). +- MacOS: + - [x] Build DMG installer; + - [ ] Build PKG installer; + - [ ] Build MAS installer; diff --git a/WARNING.md b/WARNING.md new file mode 100644 index 00000000..128ebc96 --- /dev/null +++ b/WARNING.md @@ -0,0 +1,132 @@ +# Warning + +We will replace the development of `krux-installer` from `typescript/electron` +to `python/kivy`. + +## Why the change? + +The decision was made among the members of the `selfcustody` +team for the following reasons: + +- To unify software development in Python; +- Behaviors with SSL routines, in windows, + that differ from what would be considered "normalized"; +- Failure to flash in MacOS. + +### Why unify software development in Python + +Maintenance and review of code can be more extensive. + +### What systems differ in behavior with SSL routines? + +- Windows +- MacOS + +### Why we need SSL routines? + +When downloading official krux firmware versions, it is necessary to verify +the signature through an external OpenSSL tool, as a way to verify the authenticity +of the downloaded binaries. + +## Why behaviors with SSL routines differ? + +We need to pack an external `openssl` into `krux-installer` package. + +### Why? + +On "Unix like" releases (Linux and MacOS), verification is easily done +since such tool exists natively in the operating system. +In windows release, we are faced with the peculiarity of the operating +system in question. Windows does not natively have such a tool +(see this [issue](https://github.com/qlrd/krux-installer/issues/2)). + +### How has it been resolved so far? + +We compiled a stable version of OpenSSL from the +[source](https://github.com/openssl/openssl) and packaged it on our software. + +#### This isn't insecure? + +We believe not, since the compilation process +is done entirely in a reproducible virtual environment and, +therefore, not locally, with the github-action +[compile-openssl-windows-action](https://github.com/qlrd/compile-openssl-windows-action/actions). + +## MacOS: how flash fails? + +The application works until you try to flash the device. Once you try +to flash, a message like this will appear: + +```bash +Error: 0:336: execution error: [1047] Cannot open PyInstaller +archive from executable +(/Users/user/Documents/krux-installer/krux-v23.09.0/ktool-mac) +or external archive +(/Users/user/Documents/krux-installer/krux-v23.09.0/ktool-mac.pkg) (255) + + at Socket. (/Applications/krux-installer.app/Contents/Resources/app.asar/dist-electron/main/index.js:6:381) + at Socket.emit (node:events:513:28) + at addChunk (node:internal/streams/readable:324:12) + at readableAddChunk (node:internal/streams/readable:297:9) + at Socket.push (node:internal/streams/readable:234:10) + at Pipe.onStreamRead (node:internal/stream_base_commons:190:23) +``` + +### What this means? + +This means that the `ktool-mac`, aka the "flasher", +in `krux-installer` failed to be executed. + +### Why this happen? + +Although we don't know for sure, we suspect that: + +- (1) The `krux-installer` download `ktool-mac` from a source +that `apple` did not recognize as "safe"; +- (2) If it isn't "safe", `macOS` adds an [extended file permission](https://apple.stackexchange.com/questions/42177/what-does-signify-in-unix-file-permissions); +- (3) This extended file permission puts the `ktool-mac` in a quarantine; +- (4) flash will not work. + +## And why not use a nodejs module, instead an external tool, to verify? + +The usage of SSL routines, in nodejs is done by +[Native Node Modules](https://www.electronjs.org/docs/latest/tutorial/using-native-node-modules). + +### And? + +As stated by `electron` documentation: + +> Native Node.js modules are supported by Electron, +but since Electron has a different application binary interface (ABI) +from a given Node.js binary (due to **differences such as using Chromium's +BoringSSL instead of OpenSSL**) + +### What's BoringSSL? + +As stated by BoringSSL [`README`](https://github.com/google/boringssl): + +> BoringSSL is a fork of OpenSSL that is designed to meet Google's needs. + +### How BoringSSL affects krux-installer? + +The [curve used](https://github.com/selfcustody/krux/blob/7add64a0fa8cdae65e49f8bd9bd0f7ff09e95e84/krux#L151) +to sign the firmware is `secp256k1` (the same used in Bitcoin). + +The BoringSSL [does not implement +`secp256k1`](https://github.com/electron/electron/issues/32535) and, +therefore, it is not possible +to check this curve using javascript code in electron. + +## These can be solved with a python module? + +Yes, we believe so; + +### Which module? + +[pyOpenSSL](https://pypi.org/project/pyOpenSSL/); + +### And why do you believe that? + +We've already made an experiment with +[`krux-file-signer`](https://github.com/selfcustody/krux-file-signer/blob/c541dbc730f833d64c068245fae30a42bc3f2580/src/cli/verifyer.py#L97) +in linux and windows. diff --git a/electron/main/index.ts b/electron/main/index.ts index 5e1f77ae..1513727a 100644 --- a/electron/main/index.ts +++ b/electron/main/index.ts @@ -20,92 +20,67 @@ const kruxInstaller = new App(`KruxInstaller | v${version}`) kruxInstaller.start(async ({ app, win, ipcMain}) => { // Create storage const storageBuilder = new Storage(app) - const store = await storageBuilder.build() + app.store = await storageBuilder.build() // Reset configurations - store.set('device', 'Select device') - store.set('version', 'Select version') - store.set('versions', []) + app.store.set('device', 'Select device') + app.store.set('version', 'Select version') + app.store.set('versions', []) // Create download resource handler - const changePage = new ChangePageHandler(win, store, ipcMain) + const changePage = new ChangePageHandler(win, app.store, ipcMain) changePage.build() // Create download resource handler - const downloadResource = new DownloadResourcesHandler(win, store, ipcMain) + const downloadResource = new DownloadResourcesHandler(win, app.store, ipcMain) downloadResource.build() // Create check resource handler - const checkResource = new CheckResourcesHandler(win, store, ipcMain) + const checkResource = new CheckResourcesHandler(win, app.store, ipcMain) checkResource.build() // Create unzip resource handler - const unzipResource = new UnzipResourceHandler(win, store, ipcMain) + const unzipResource = new UnzipResourceHandler(win, app.store, ipcMain) unzipResource.build() // Create fetcher for newest official release handler - const verifyOfficialReleasesFetch = new VerifyOfficialReleasesFetchHandler(win, store, ipcMain) + const verifyOfficialReleasesFetch = new VerifyOfficialReleasesFetchHandler(win, app.store, ipcMain) verifyOfficialReleasesFetch.build() // Create handler for official release sha256.txt - const verifyOfficialReleasesHash = new VerifyOfficialReleasesHashHandler(win, store, ipcMain) + const verifyOfficialReleasesHash = new VerifyOfficialReleasesHashHandler(win, app.store, ipcMain) verifyOfficialReleasesHash.build() // Create handler for official release .sig and .pem handler - const verifyOfficialReleasesSign = new VerifyOfficialReleasesSignHandler(win, store, ipcMain) + const verifyOfficialReleasesSign = new VerifyOfficialReleasesSignHandler(win, app.store, ipcMain) verifyOfficialReleasesSign.build() // Create handler for verify existence of openssl - const verifyOpenssl = new VerifyOpensslHandler(win, store, ipcMain) + const verifyOpenssl = new VerifyOpensslHandler(win, app.store, ipcMain) verifyOpenssl.build() // Create store setter handler - const storeSet = new StoreSetHandler(win, store, ipcMain) + const storeSet = new StoreSetHandler(win, app.store, ipcMain) storeSet.build() // Create store getter handler - const storeGet = new StoreGetHandler(win, store, ipcMain) + const storeGet = new StoreGetHandler(win, app.store, ipcMain) storeGet.build() // Create 'check if it will flash' handler - const checkIfItWillFlashHandler = new CheckIfItWillFlashHandler(win, store, ipcMain) + const checkIfItWillFlashHandler = new CheckIfItWillFlashHandler(win, app.store, ipcMain) checkIfItWillFlashHandler.build() // Create flash' handler - const flashHandler = new FlashHandler(win, store, ipcMain) + const flashHandler = new FlashHandler(win, app.store, ipcMain) flashHandler.build() // Create Wdio test handlers // if environment variable WDIO_ELECTRON equals 'true' - if (process.env.TEST === 'true' && process.env.WDIO_ELECTRON === 'true') { - win.webContents.send('building ipcMain.handle for \'wdio-electron.app\'') - ipcMain.handle('wdio-electron.app', (_event, funcName, ...args) => { - const appProp = app[funcName]; - if (typeof appProp === 'function') { - return appProp.apply(app, args); - } - return appProp; - }); - - win.webContents.send('building ipcMain.handle for \'wdio-electron\'') - ipcMain.handle('wdio-electron', (_events, ...args) => { - return { - appData: app.getPath('appData'), - documents: app.getPath('documents'), - store: { - appVersion: store.get('appVersion'), - resources: store.get('resources'), - os: store.get('os'), - versions: store.get('versions'), - version: store.get('version'), - device: store.get('device'), - sdcard: store.get('sdcard'), - showFlash: store.get('showFlash') - } - } + if (process.env.NODE_ENV === 'test') { + const _electron = await import('electron') + ipcMain.handle("wdio-electron.execute", (_, script, args) => { + return new Function(`return (${script}).apply(this, arguments)`)(_electron, ...args); }) - } else { - win.webContents.send("skip build ipcMain.handle for 'wdio-electron.app'") - win.webContents.send("skip build ipcMain.handle for 'wdio-electron'") } }) diff --git a/electron/preload/index.ts b/electron/preload/index.ts index a676f89b..4b0551e6 100644 --- a/electron/preload/index.ts +++ b/electron/preload/index.ts @@ -4,28 +4,10 @@ ipcRenderer.on('main-process-message', (_event, args) => { console.log(args) }) -if (process.env.TEST === 'true') { - const validChannels = [ - 'wdio-electron', - 'wdio-electron.app' - ]; - const invoke = async (channel, ...data) => { - if (!validChannels.includes(channel)) { - throw new Error(`Channel "${channel}" is invalid`); - } - if (!process.env.WDIO_ELECTRON) { - throw new Error('Electron APIs can not be invoked outside of WDIO'); - } - return ipcRenderer.invoke(channel, ...data); - }; +if (process.env.NODE_ENV === 'test') { contextBridge.exposeInMainWorld('wdioElectron', { - app: { - invoke: (funcName, ...args) => invoke('wdio-electron.app', funcName, ...args), - }, - custom: { - invoke: (...args) => invoke('wdio-electron', ...args), - } - }); + execute: (script, args) => ipcRenderer.invoke("wdio-electron.execute", script, args) + }) } contextBridge.exposeInMainWorld('api', { diff --git a/images/vscodium.png b/images/vscodium.png new file mode 100644 index 00000000..dbb72525 Binary files /dev/null and b/images/vscodium.png differ diff --git a/images/vscodium_debug.png b/images/vscodium_debug.png new file mode 100644 index 00000000..eec8d702 Binary files /dev/null and b/images/vscodium_debug.png differ diff --git a/lib/check-resource.ts b/lib/check-resource.ts index 4489a8ea..0df29ce9 100644 --- a/lib/check-resource.ts +++ b/lib/check-resource.ts @@ -42,7 +42,6 @@ export default class CheckResourcesHandler extends Handler { build () { super.build(async (options) => { try { - console.log(options) const resources = this.storage.get('resources') as string const destinationResource = join(resources, options.resource) diff --git a/lib/download-resources.ts b/lib/download-resources.ts index 2892b638..c8150d36 100644 --- a/lib/download-resources.ts +++ b/lib/download-resources.ts @@ -59,7 +59,6 @@ export default class DownloadResourcesHandler extends Handler { this.log(options) const destinationResource = dirname(resourceTo) - console.log(destinationResource) try { // First check if destination resource exists diff --git a/lib/storage.ts b/lib/storage.ts index 4bed2654..271ae858 100644 --- a/lib/storage.ts +++ b/lib/storage.ts @@ -46,9 +46,6 @@ export default class Storage extends Base { type: 'string', regex: /maixpy_(m5stickv5|amigo|dock|bit)/g }, - sdcard: { - type: 'string' - }, showFlash: { type: 'boolean' } @@ -126,7 +123,6 @@ export default class Storage extends Base { const versions = [] const version = 'Select version' const device = 'Select device' - const sdcard = '' let isMac10 = false const showFlash = false @@ -141,7 +137,6 @@ export default class Storage extends Base { store.set('versions', versions) store.set('version', version) store.set('device', device) - store.set('sdcard', sdcard) store.set('showFlash', showFlash) const keys = Object.keys(this.config) diff --git a/package.json b/package.json index 66436e04..c2129c83 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,6 @@ { "name": "krux-installer", - "version": "0.0.1-beta", - "revision": "2f0ee130", + "version": "0.0.1", "main": "dist-electron/main/index.js", "description": "Graphical User Interface to download, verify and flash Krux´s firmware on Kendryte K210 hardwares as bitcoin signature devices", "author": "qlrd <106913782+qlrd@users.noreply.github.com>", @@ -26,7 +25,8 @@ }, "e2e": { "env": { - "DEBUG": "krux:*" + "DEBUG": "krux:*", + "NODE_ENV": "test" }, "run": "echo Running E2E" } @@ -36,8 +36,11 @@ "build": "vue-tsc --noEmit && vite build && electron-builder", "preview": "vite preview", "e2e": "wdio run wdio.conf.mts", - "lint:md": "markdownlint README.md --ignore node_modules", - "make:revision": "sha256sum yarn.lock | cut -c -8" + "lint:readme": "markdownlint README.md --ignore node_modules", + "lint:changelog": "markdownlint CHANGELOG.md --ignore node_modules", + "lint:warning": "markdownlint WARNING.md --ignore node_modules", + "lint:todo": "markdownlint TODO.md --ignore node_modules", + "lint": "yarn run lint:readme && yarn run lint:changelog && yarn run lint:warning && yarn run lint:todo" }, "devDependencies": { "@babel/cli": "^7.22.9", @@ -48,30 +51,30 @@ "@types/command-exists": "^1.2.0", "@types/debug": "^4.1.7", "@types/mocha": "^10.0.1", - "@types/node": "^20.4.3", + "@types/node": "^20.10.5", "@vitejs/plugin-vue": "^4.1.0", - "@wdio/cli": "^8.13.5", - "@wdio/globals": "^8.13.4", - "@wdio/local-runner": "^8.13.4", - "@wdio/mocha-framework": "^8.12.1", - "@wdio/spec-reporter": "^8.12.2", + "@wdio/cli": "^8.27.0", + "@wdio/globals": "^8.27.0", + "@wdio/local-runner": "^8.27.0", + "@wdio/mocha-framework": "^8.27.0", + "@wdio/spec-reporter": "^8.27.0", "chai": "^4.3.7", - "electron": "^27.0.2", + "electron": "^28.1.0", "electron-builder": "^24.4.0", "glob": "^10.3.3", - "markdownlint-cli": "^0.37.0", + "markdownlint-cli": "^0.38.0", "mocha": "^10.2.0", "os-lang": "^3.1.1", "rimraf": "^5.0.1", "ts-node": "^10.9.1", "typescript": "^5.1.6", - "vite": "^4.4.6", - "vite-plugin-electron": "^0.14.1", + "vite": "^5.0.10", + "vite-plugin-electron": "^0.15.5", "vite-plugin-electron-renderer": "^0.14.1", "vite-plugin-html": "^3.2.0", - "vue": "^3.2.47", - "vue-tsc": "^1.8.6", - "wdio-electron-service": "^5.3.0" + "vue": "^3.3.13", + "vue-tsc": "^1.8.26", + "wdio-electron-service": "^6.0.2" }, "dependencies": { "@o/electron-sudo": "^2.8.23", @@ -80,9 +83,9 @@ "command-exists": "^1.2.9", "debug": "^4.3.4", "electron-store": "^8.1.0", - "vite-plugin-vuetify": "^1.0.2", + "vite-plugin-vuetify": "^2.0.1", "vue-asciimorph": "^0.0.3", - "vuetify": "^3.3.9", + "vuetify": "^3.4.8", "yauzl": "^2.10.0" } } diff --git a/src/assets/vite.svg b/src/assets/vite.svg deleted file mode 100644 index e7b8dfb1..00000000 --- a/src/assets/vite.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/src/assets/vue.svg b/src/assets/vue.svg deleted file mode 100644 index 770e9d33..00000000 --- a/src/assets/vue.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/src/pages/ConsoleLoad.vue b/src/pages/ConsoleLoad.vue index ab169be1..eaad26cc 100644 --- a/src/pages/ConsoleLoad.vue +++ b/src/pages/ConsoleLoad.vue @@ -54,7 +54,6 @@ function toDashes(msg: string) { // windows need to replace \ to - tag = tag.replace(/\\/g, '-') - console.log(tag) return tag } \ No newline at end of file diff --git a/test/e2e/pageobjects/app.page.ts b/test/e2e/pageobjects/app.page.ts index da63b237..6341734c 100644 --- a/test/e2e/pageobjects/app.page.ts +++ b/test/e2e/pageobjects/app.page.ts @@ -148,10 +148,10 @@ class App { this.__select_device_page_maixpy_back_text__ = 'div#select-device-page-back-text' this.__select_version_page__ = 'div#select-version-page'; - this.__select_version_page_selfcustody_button__ = 'div#select-version-page-selfcustody-krux-releases-tag-v23-09-0-button' + this.__select_version_page_selfcustody_button__ = 'div#select-version-page-selfcustody-krux-releases-tag-v23-09-1-button' this.__select_version_page_back_button__ = 'div#select-version-page-back-button' this.__select_version_page_odudex_button__ = 'div#select-version-page-odudex-krux-binaries-button' - this.__select_version_page_selfcustody_text__ = 'div#select-version-page-selfcustody-krux-releases-tag-v23-09-0-text' + this.__select_version_page_selfcustody_text__ = 'div#select-version-page-selfcustody-krux-releases-tag-v23-09-1-text' this.__select_version_page_odudex_text__ = 'div#select-version-page-odudex-krux-binaries-text' this.__select_version_page_back_text__ = 'div#select-version-page-back-text' @@ -162,22 +162,22 @@ class App { this.__download_official_release_zip_subtitle__ = 'div#download-official-release-zip-page-subtitle' this.__download_official_release_zip_progress__ = 'div#download-official-release-zip-page-progress' - this.__checking_release_zip_msg__ = 'pre#checking-v23-09-0-krux-v23-09-0-zip' - this.__not_found_release_zip_msg__ = 'pre#v23-09-0-krux-v23-09-0-zip-not-found' - this.__found_release_zip_msg__ = 'pre#v23-09-0-krux-v23-09-0-zip-found' + this.__checking_release_zip_msg__ = 'pre#checking-v23-09-1-krux-v23-09-1-zip' + this.__not_found_release_zip_msg__ = 'pre#v23-09-1-krux-v23-09-1-zip-not-found' + this.__found_release_zip_msg__ = 'pre#v23-09-1-krux-v23-09-1-zip-found' - this.__checking_release_zip_sha256_txt_msg__ = 'pre#checking-v23-09-0-krux-v23-09-0-zip-sha256-txt' - this.__not_found_release_zip_sha256_txt_msg__ = 'pre#v23-09-0-krux-v23-09-0-zip-sha256-txt-not-found' - this.__found_release_zip_sha256_txt_msg__ = 'pre#v23-09-0-krux-v23-09-0-zip-sha256-txt-found' + this.__checking_release_zip_sha256_txt_msg__ = 'pre#checking-v23-09-1-krux-v23-09-1-zip-sha256-txt' + this.__not_found_release_zip_sha256_txt_msg__ = 'pre#v23-09-1-krux-v23-09-1-zip-sha256-txt-not-found' + this.__found_release_zip_sha256_txt_msg__ = 'pre#v23-09-1-krux-v23-09-1-zip-sha256-txt-found' this.__download_official_release_zip_sha256_txt_page__ = 'div#download-official-release-zip-sha256-txt-page' this.__download_official_release_zip_sha256_txt_page_title__ = 'div#download-official-release-zip-sha256-txt-page-title' this.__download_official_release_zip_sha256_txt_page_subtitle__ = 'div#download-official-release-zip-sha256-txt-page-subtitle' this.__download_official_release_zip_sha256_txt_page_progress__ = 'div#download-official-release-zip-sha256-txt-page-progress' - this.__checking_release_zip_sig_msg__ = 'pre#checking-v23-09-0-krux-v23-09-0-zip-sig' - this.__not_found_release_zip_sig_msg__ = 'pre#v23-09-0-krux-v23-09-0-zip-sig-not-found' - this.__found_release_zip_sig_msg__ = 'pre#v23-09-0-krux-v23-09-0-zip-sig-found' + this.__checking_release_zip_sig_msg__ = 'pre#checking-v23-09-1-krux-v23-09-1-zip-sig' + this.__not_found_release_zip_sig_msg__ = 'pre#v23-09-1-krux-v23-09-1-zip-sig-not-found' + this.__found_release_zip_sig_msg__ = 'pre#v23-09-1-krux-v23-09-1-zip-sig-found' this.__download_official_release_zip_sig_page__ = 'div#download-official-release-zip-sig-page' this.__download_official_release_zip_sig_title__ = 'div#download-official-release-zip-sig-page-title' @@ -216,8 +216,8 @@ class App { this.__verified_official_release_page__ = 'div#verified-official-release-page' this.__verified_official_release_page_sha256_integrity_title__ = 'div#verified-official-release-page-sha256-integrity-title' - this.__verified_official_release_page_sha256_integrity_txt__ = 'div#verified-official-release-page-sha256-integrity-v23-09-0-krux-v23-09-0-zip-sha256-txt' - this.__verified_official_release_page_sha256_integrity__ = 'div#verified-official-release-page-sha256-integrity-v23-09-0-krux-v23-09-0-zip' + this.__verified_official_release_page_sha256_integrity_txt__ = 'div#verified-official-release-page-sha256-integrity-v23-09-1-krux-v23-09-1-zip-sha256-txt' + this.__verified_official_release_page_sha256_integrity__ = 'div#verified-official-release-page-sha256-integrity-v23-09-1-krux-v23-09-1-zip' this.__verified_official_release_page_signature_title__ = 'div#verified-official-release-page-signature-title' this.__verified_official_release_page_signature_command__ = 'span#verified-official-release-page-signature-command' this.__verified_official_release_page_signature_result__ = 'span#verified-official-release-page-signature-result' diff --git a/test/e2e/specs/000.create-config.spec.mts b/test/e2e/specs/000.create-config.spec.mts new file mode 100644 index 00000000..64c785f8 --- /dev/null +++ b/test/e2e/specs/000.create-config.spec.mts @@ -0,0 +1,35 @@ +import { readdir, readFile } from 'fs/promises' +import { join } from 'path' +import { expect } from 'chai' +import { browser } from '@wdio/globals' +import { describe, it } from 'mocha' + +describe('KruxInstaller configuration', () => { + + it('\'appData\' property should be a path that exist within \'krux-installer\' directory', async () => { + const appData = await browser.electron.execute(function (electron) { + return electron.app.getPath('appData') + }) + const list = await readdir(appData) + expect(list.includes('krux-installer')).to.be.true + }) + + it('\'config.json\' file should exists inside \'krux-installer\' directory', async () => { + const appData = await browser.electron.execute(function (electron) { + return electron.app.getPath('appData') + }) + const dir = join(appData, 'krux-installer') + const list = await readdir(dir) + expect(list.includes('config.json')).to.be.true + }) + + it('\'config.json\' should be a readable string', async () => { + const appData = await browser.electron.execute(function (electron) { + return electron.app.getPath('appData') + }) + const filePath = join(appData, 'krux-installer', 'config.json') + const file = await readFile(filePath, 'utf-8') + expect(file).to.be.a('string') + }) + +}) diff --git a/test/e2e/specs/000.create-config.spec.ts b/test/e2e/specs/000.create-config.spec.ts deleted file mode 100644 index 75399f01..00000000 --- a/test/e2e/specs/000.create-config.spec.ts +++ /dev/null @@ -1,52 +0,0 @@ -const { readdir, readFile } = require('fs/promises') -const { join } = require('path') -const expectChai = require('chai').expect -const { browser } = require('@wdio/globals') -const { describe, it } = require('mocha') -const { version } = require('../../../package.json') - -describe('KruxInstaller configuration', () => { - - it('should \'appData\' path exist with \'krux-installer\' directory', async () => { - try { - const api = await browser.electron.api() as Record - const list = await readdir(api.appData) - expectChai(list.includes('krux-installer')).to.be.true - } catch (error) { - console.log(error) - } - }) - - it('should \'documents\' path exist with \'krux-installer\' directory', async () => { - try { - const api = await browser.electron.api() as Record - const list = await readdir(api.documents) - expectChai(list.includes('krux-installer')).to.be.true - } catch (error) { - console.log(error) - } - }) - - it('should \'config.json\' file exists inside \'krux-installer\' directory', async () => { - try { - const api = await browser.electron.api() as Record - const dir = join(api.appData, 'krux-installer') - const list = await readdir(dir) - expectChai(list.includes('config.json')).to.be.true - } catch (error) { - console.log(error) - } - }) - - it('should \'config.json\' be a readable string', async () => { - try { - const api = await browser.electron.api() as Record - const filePath = join(api.appData, 'krux-installer', 'config.json') - const file = await readFile(filePath) - expectChai(file).to.be.a('string') - } catch (error) { - console.log(error) - } - }) - -}) diff --git a/test/e2e/specs/001.check-config.spec.mts b/test/e2e/specs/001.check-config.spec.mts new file mode 100644 index 00000000..089f03cf --- /dev/null +++ b/test/e2e/specs/001.check-config.spec.mts @@ -0,0 +1,89 @@ +import { expect } from 'chai' +import { browser } from '@wdio/globals' +import { describe, it } from 'mocha' +import { createRequire } from 'module' +const { version } = createRequire(import.meta.url)('../../../package.json') + +describe('Check created configuration', () => { + + it('\'appVersion\' property should be equal to the value defined in package.json', async () => { + const appVersion = await browser.electron.execute(function (electron) { + return electron.app.getVersion() + }) + expect(appVersion).to.equal(version) + }) + + it('\'resources\' property should be properly set for the platform', async () => { + const resources = await browser.electron.execute(function (electron) { + return electron.app.store.get('resources') + }) + + let regexp: RegExp + + if (process.env.CI && process.env.GITHUB_ACTION) { + if (process.platform === 'linux') { + regexp = new RegExp(`/home/[a-zA-Z0-9/]+`, 'g') + expect(resources).to.match(regexp) + } + if (process.platform === 'win32') { + regexp = /[A-Z]:[a-zA-Z\\-]+/g + expect(resources).to.match(regexp as RegExp) + } + if (process.platform === 'darwin') { + regexp = new RegExp('/Users/[a-zA-Z0-9/-]+', 'g') + expect(resources).to.match(regexp as RegExp) + } + } else { + const docs = 'Documents|Documentos|Documenten|Documenti|Unterlagen' + if (process.platform === 'linux') { + regexp = new RegExp(`/home/[a-zA-Z0-9/]+/(${docs})`, 'g') + expect(resources).to.match(regexp as RegExp) + } + if (process.platform === 'win32') { + regexp = new RegExp(`[A-Z]:\\Users\\[a-zA-Z0-9]+\\(${docs})\\${name}`, 'g') + expect(resources).to.match(regexp as RegExp) + } + if (process.platform === 'darwin') { + regexp = new RegExp(`/Users/[a-zA-Z0-9\/\-]+/(${docs})/${name}`, 'g') + expect(resources).to.match(regexp as RegExp) + } + } + }) + + it('\'os\' property should be properly set for the platform', async () => { + const os = await browser.electron.execute(function (electron) { + return electron.app.store.get('os') + }) + expect(os).to.equal(process.platform) + }) + + it('\'versions\' property should be an Array with 0 elements', async () => { + const versions = await browser.electron.execute(function (electron) { + return electron.app.store.get('versions') + }) + expect(versions).to.be.an('Array') + expect(versions.length).to.equal(0) + }) + + it('\'version\' property should be equal to \'Select version\'', async () => { + const version = await browser.electron.execute(function (electron) { + return electron.app.store.get('version') + }) + expect(version).to.equal('Select version') + }) + + it('\'device\' property should be equal to \'Select device\'', async () => { + const device = await browser.electron.execute(function (electron) { + return electron.app.store.get('device') + }) + expect(device).to.equal('Select device') + }) + + it('\'device\' property should be equal to \'Select device\'', async () => { + const showFlash = await browser.electron.execute(function (electron) { + return electron.app.store.get('showFlash') + }) + expect(showFlash).to.equal(false) + }) + +}) diff --git a/test/e2e/specs/001.check-config.spec.ts b/test/e2e/specs/001.check-config.spec.ts deleted file mode 100644 index 6ba16e70..00000000 --- a/test/e2e/specs/001.check-config.spec.ts +++ /dev/null @@ -1,80 +0,0 @@ -const { readdir, readFile } = require('fs/promises') -const { join } = require('path') -const expectChai = require('chai').expect -const { browser } = require('@wdio/globals') -const { describe, it } = require('mocha') -const { version } = require('../../../package.json') - -describe('Check created configuration', () => { - - it('should \'appVersion\' property be equal to the defined in package.json', async () => { - const api = await browser.electron.api() as Record - expectChai(api.store.appVersion).to.equal(version) - }) - - it('should \'resources\' property be properly set for the platform', async () => { - const api = await browser.electron.api() as Record - let regexp: RegExp - - if (process.env.CI && process.env.GITHUB_ACTION) { - if (process.platform === 'linux') { - regexp = new RegExp(`/home/[a-zA-Z0-9/]+`, 'g') - expectChai(api.store.resources).to.match(regexp) - } - if (process.platform === 'win32') { - regexp = /[A-Z]:[a-zA-Z\\-]+/g - expectChai(api.store.resources).to.match(regexp as RegExp) - } - if (process.platform === 'darwin') { - regexp = new RegExp('/Users/[a-zA-Z0-9/-]+', 'g') - expectChai(api.store.resources).to.match(regexp as RegExp) - } - } else { - const docs = 'Documents|Documentos|Documenten|Documenti|Unterlagen' - if (process.platform === 'linux') { - regexp = new RegExp(`/home/[a-zA-Z0-9/]+/(${docs})`, 'g') - expectChai(api.store.resources).to.match(regexp as RegExp) - } - if (process.platform === 'win32') { - regexp = new RegExp(`[A-Z]:\\Users\\[a-zA-Z0-9]+\\(${docs})\\${name}`, 'g') - expectChai(api.store.resources).to.match(regexp as RegExp) - } - if (process.platform === 'darwin') { - regexp = new RegExp(`/Users/[a-zA-Z0-9\/\-]+/(${docs})/${name}`, 'g') - expectChai(api.store.resources).to.match(regexp as RegExp) - } - } - }) - - it('should \'os\' property be properly set for the platform', async () => { - const api = await browser.electron.api() as Record - expectChai(api.store.os).to.equal(process.platform) - }) - - it('should \'versions\' property to be an Array with 0 elements', async () => { - const api = await browser.electron.api() as Record - expectChai(api.store.versions).to.be.an('Array') - expectChai(api.store.versions.length).to.equal(0) - }) - - it('should \'version\' property to be equal \'Select version\'', async () => { - const api = await browser.electron.api() as Record - expectChai(api.store.version).to.equal('Select version') - }) - - it('should \'device\' property to be equal \'Select device\'', async () => { - const api = await browser.electron.api() as Record - expectChai(api.store.device).to.equal('Select device') - }) - - it('should \'sdcard\' property to be equal \'\'', async () => { - const api = await browser.electron.api() as Record - expectChai(api.store.sdcard).to.equal('') - }) - - it('should \'showFlash\' property to be equal \'false\'', async () => { - const api = await browser.electron.api() as Record - expectChai(api.store.showFlash).to.equal(false) - }) - -}) diff --git a/test/e2e/specs/002.app-startup.spec.mts b/test/e2e/specs/002.app-startup.spec.mts new file mode 100644 index 00000000..4d739a11 --- /dev/null +++ b/test/e2e/specs/002.app-startup.spec.mts @@ -0,0 +1,28 @@ +import { expect } from 'chai' +import { browser } from '@wdio/globals' +import { describe, it } from 'mocha' + +describe('KruxInstaller start up', () => { + + it('should be ready', async () => { + const isReady = await browser.electron.execute(function (electron) { + return electron.app.isReady() + }) + expect(isReady).to.be.equal(true) + }) + + it('application name should be correct', async () => { + const name = await browser.electron.execute(function (electron) { + return electron.app.getName() + }) + expect(name).to.be.equal('krux-installer') + }) + + it('application version should be correct', async () => { + const version = await browser.electron.execute(function (electron) { + return electron.app.getVersion() + }) + expect(version).to.be.equal('0.0.1') + }) + +}) diff --git a/test/e2e/specs/002.app-startup.spec.ts b/test/e2e/specs/002.app-startup.spec.ts deleted file mode 100644 index 687e1915..00000000 --- a/test/e2e/specs/002.app-startup.spec.ts +++ /dev/null @@ -1,23 +0,0 @@ -const expectChai = require('chai').expect -const { describe, it } = require('mocha') -const { browser } = require('@wdio/globals') -const pkg = require('../../../package.json') - -describe('KruxInstaller start up', () => { - - it('should be ready', async () => { - const isReady = await browser.electron.app('isReady') as boolean - expectChai(isReady).to.be.equal(true) - }) - - it('should name be correct', async () => { - const name = await browser.electron.app('getName') as string - expectChai(name).to.be.equal(pkg.name) - }) - - it('should version be correct', async () => { - const version = await browser.electron.app('getVersion') as string - expectChai(version).to.be.equal(pkg.version) - }) - -}) diff --git a/test/e2e/specs/003.app-logo.spec.ts b/test/e2e/specs/003.app-logo.spec.mts similarity index 65% rename from test/e2e/specs/003.app-logo.spec.ts rename to test/e2e/specs/003.app-logo.spec.mts index 57ea555d..ed434009 100644 --- a/test/e2e/specs/003.app-logo.spec.ts +++ b/test/e2e/specs/003.app-logo.spec.mts @@ -1,8 +1,8 @@ -const expectChai = require('chai').expect -const expectWDIO = require('@wdio/globals').expect -const { describe, it } = require('mocha') +import { expect } from '@wdio/globals' +import { describe, it } from 'mocha' +import { createRequire } from 'module' -const App = require('../pageobjects/app.page') +const App = createRequire(import.meta.url)('../pageobjects/app.page') // When wdio gets the generated //
 html tag from vue-ascii-morph,
@@ -31,21 +31,21 @@ describe('KruxInstaller initialization', () => {
     instance = new App()
   })
 
-  it('should #app html exist', async () => { 
+  it('\'#app\' html tag should exist', async () => { 
     await instance.app.waitForExist({ timeout: 5000 })
   })
 
-  it('should main tag exist', async () => { 
+  it('\'#main\' html tag should exist', async () => { 
     await instance.main.waitForExist({ timeout: 5000 })
   })
 
-  it('should krux-installer logo appears', async () => { 
+  it('krux-installer logo should appears', async () => { 
     await instance.logo.waitForExist({ timeout: 3000 })
-    await expectWDIO(instance.logo).toBeDisplayed()
-    await expectWDIO(instance.logo).toHaveText(KRUX_INSTALLER_LOGO)
+    await expect(instance.logo).toBeDisplayed()
+    await expect(instance.logo).toHaveText(KRUX_INSTALLER_LOGO)
   })
 
-  it('should krux-installer logo disappears', async () => { 
+  it('krux-installer logo should disappear', async () => { 
     await instance.logo.waitForExist({ timeout: 3000, reverse: true })
   })
 })
diff --git a/test/e2e/specs/004.app-consoleload-before-main-page.spec.ts b/test/e2e/specs/004.app-consoleload-before-main-page.spec.mts
similarity index 66%
rename from test/e2e/specs/004.app-consoleload-before-main-page.spec.ts
rename to test/e2e/specs/004.app-consoleload-before-main-page.spec.mts
index 6ea01940..b5fc16d6 100644
--- a/test/e2e/specs/004.app-consoleload-before-main-page.spec.ts
+++ b/test/e2e/specs/004.app-consoleload-before-main-page.spec.mts
@@ -1,8 +1,9 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
+
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
-const App = require('../pageobjects/app.page')
 
 // When wdio gets the generated
 // 
 html tag from vue-ascii-morph,
@@ -23,29 +24,29 @@ describe('KruxInstaller loading messages', () => {
 
   it('should \'Loading data from storage\' message appears', async () => {
     await instance.loadingDataMsg.waitForExist({ timeout: 3000 })
-    await expectWDIO(instance.loadingDataMsg).toBeDisplayed()
-    await expectWDIO(instance.loadingDataMsg).toHaveText(LOADING_DATA_MESSAGE)
+    await expect(instance.loadingDataMsg).toBeDisplayed()
+    await expect(instance.loadingDataMsg).toHaveText(LOADING_DATA_MESSAGE)
   })
 
   it('should \'Verifying openssl\' message appears', async () => {
     await instance.verifyingOpensslMsg.waitForExist({ timeout: 6000 })
-    await expectWDIO(instance.verifyingOpensslMsg).toBeDisplayed()
-    await expectWDIO(instance.verifyingOpensslMsg).toHaveText(VERIFYING_OPENSSL_MESSAGE)
+    await expect(instance.verifyingOpensslMsg).toBeDisplayed()
+    await expect(instance.verifyingOpensslMsg).toHaveText(VERIFYING_OPENSSL_MESSAGE)
   })
 
   it('should \'openssl for  found\' message appears', async () => {
     if (process.platform === 'linux') {
       await instance.opensslForLinuxFound.waitForExist({ timeout: 9000 })
-      await expectWDIO(instance.opensslForLinuxFound).toBeDisplayed()
-      await expectWDIO(instance.opensslForLinuxFound).toHaveText(OPENSSL_FOUND_LINUX_MESSAGE)
+      await expect(instance.opensslForLinuxFound).toBeDisplayed()
+      await expect(instance.opensslForLinuxFound).toHaveText(OPENSSL_FOUND_LINUX_MESSAGE)
     } else if (process.platform === 'darwin') {
       await instance.opensslForDarwinFound.waitForExist({ timeout: 9000 })
-      await expectWDIO(instance.verifyingOpensslMsg).toBeDisplayed()
-      await expectWDIO(instance.opensslForDarwinFound).toHaveText(OPENSSL_FOUND_DARWIN_MESSAGE)
+      await expect(instance.verifyingOpensslMsg).toBeDisplayed()
+      await expect(instance.opensslForDarwinFound).toHaveText(OPENSSL_FOUND_DARWIN_MESSAGE)
     } else if (process.platform === 'win32') {
       await instance.opensslForWin32Found.waitForExist({ timeout: 9000 })
-      await expectWDIO(instance.verifyingOpensslMsg).toBeDisplayed()
-      await expectWDIO(instance.opensslForWin32Found).toHaveText(OPENSSL_FOUND_WIN32_MESSAGE)
+      await expect(instance.verifyingOpensslMsg).toBeDisplayed()
+      await expect(instance.opensslForWin32Found).toHaveText(OPENSSL_FOUND_WIN32_MESSAGE)
     }
     
   })
diff --git a/test/e2e/specs/005.main-menu.spec.ts b/test/e2e/specs/005.main-menu.spec.mts
similarity index 68%
rename from test/e2e/specs/005.main-menu.spec.ts
rename to test/e2e/specs/005.main-menu.spec.mts
index 04fa46d5..72ca34e8 100644
--- a/test/e2e/specs/005.main-menu.spec.ts
+++ b/test/e2e/specs/005.main-menu.spec.mts
@@ -1,12 +1,11 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 const SELECT_DEVICE_TEXT = 'Select device'
 const SELECT_VERSION_TEXT = 'Select version'
-const PLEASE_SELECT_VERSION_MESSAGE = 'Please click \'Select version\' to download sources'
 
 describe('KruxInstaller Main page', () => {
 
@@ -36,30 +35,30 @@ describe('KruxInstaller Main page', () => {
   })
 
   it('should main page appears', async () => {
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
   it('should message text not appears', async () => {
-    await expectWDIO(instance.mainClickMessageText).not.toBeDisplayed()
+    await expect(instance.mainClickMessageText).not.toBeDisplayed()
   })
 
   it('should \'Select device\' button appears', async () => {
-    await expectWDIO(instance.mainSelectDeviceButton).toBeDisplayed()
+    await expect(instance.mainSelectDeviceButton).toBeDisplayed()
   })
 
   it('should \'Select version\' button appears', async () => {
-    await expectWDIO(instance.mainSelectVersionButton).toBeDisplayed()
+    await expect(instance.mainSelectVersionButton).toBeDisplayed()
   })
 
   it('should \'Select device\' button have \'Select device\' text', async () => {
-    await expectWDIO(instance.mainSelectDeviceText).toHaveText(SELECT_DEVICE_TEXT)
+    await expect(instance.mainSelectDeviceText).toHaveText(SELECT_DEVICE_TEXT)
   })
 
   it('should \'Select version\' button have \'Select version\' text', async () => {
-    await expectWDIO(instance.mainSelectVersionText).toHaveText(SELECT_VERSION_TEXT)
+    await expect(instance.mainSelectVersionText).toHaveText(SELECT_VERSION_TEXT)
   })
 
   it('should \'Flash\' button not appears', async () => {
-    await expectWDIO(instance.mainSelectFlashButton).not.toBeDisplayed()
+    await expect(instance.mainSelectFlashButton).not.toBeDisplayed()
   })
 })
diff --git a/test/e2e/specs/006.select-device-show-only.spec.ts b/test/e2e/specs/006.select-device-show-only.spec.mts
similarity index 69%
rename from test/e2e/specs/006.select-device-show-only.spec.ts
rename to test/e2e/specs/006.select-device-show-only.spec.mts
index ee75a5f5..e5be4f51 100644
--- a/test/e2e/specs/006.select-device-show-only.spec.ts
+++ b/test/e2e/specs/006.select-device-show-only.spec.mts
@@ -1,12 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
-
-const SELECT_DEVICE_TEXT = 'Select device'
-const SELECT_VERSION_TEXT = 'Select version'
-const PLEASE_SELECT_VERSION_MESSAGE = 'Please click \'Select version\' to download sources'
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectDevice page (show only)', () => {
 
@@ -39,66 +35,66 @@ describe('KruxInstaller SelectDevice page (show only)', () => {
     await instance.mainSelectDeviceButton.click()
     await instance.mainPage.waitForExist({ reverse: true })
     await instance.selectDevicePage.waitForExist()
-    await expectWDIO(instance.selectDevicePage).toBeDisplayed()
+    await expect(instance.selectDevicePage).toBeDisplayed()
   })
 
   it('should \'maixpy_m5stickv\' button be displayed', async () => {
     await instance.selectMaixpyM5StickVButton.waitForExist()
-    await expectWDIO(instance.selectMaixpyM5StickVButton).toBeDisplayed()
+    await expect(instance.selectMaixpyM5StickVButton).toBeDisplayed()
   })
 
   it('should \'maixpy_m5stickv\' button have \'maixpy_m5stickv\' text', async () => { 
     await instance.selectMaixpyM5StickVText.waitForExist()
-    await expectWDIO(instance.selectMaixpyM5StickVText).toHaveText('maixpy_m5stickv')
+    await expect(instance.selectMaixpyM5StickVText).toHaveText('maixpy_m5stickv')
   })
 
   it('should \'maixpy_amigo_ips\' button be displayed', async () => {
     await instance.selectMaixpyAmigoIpsButton.waitForExist()
-    await expectWDIO(instance.selectMaixpyAmigoIpsButton).toBeDisplayed()
+    await expect(instance.selectMaixpyAmigoIpsButton).toBeDisplayed()
   })
 
   it('should \'maixpy_amigo_ips\' button have \'maixpy_amigo_ips\' text', async () => { 
     await instance.selectMaixpyAmigoIpsText.waitForExist()
-    await expectWDIO(instance.selectMaixpyAmigoIpsText).toHaveText('maixpy_amigo_ips')
+    await expect(instance.selectMaixpyAmigoIpsText).toHaveText('maixpy_amigo_ips')
   })
 
   it('should \'maixpy_amigo_tft\' button be displayed', async () => {
     await instance.selectMaixpyAmigoTftButton.waitForExist()
-    await expectWDIO(instance.selectMaixpyAmigoTftButton).toBeDisplayed()
+    await expect(instance.selectMaixpyAmigoTftButton).toBeDisplayed()
   })
 
   it('should \'maixpy_amigo_tft\' button have \'maixpy_amigo_tft\' text', async () => { 
     await instance.selectMaixpyAmigoTftText.waitForExist()
-    await expectWDIO(instance.selectMaixpyAmigoTftText).toHaveText('maixpy_amigo_tft')
+    await expect(instance.selectMaixpyAmigoTftText).toHaveText('maixpy_amigo_tft')
   })
 
   it('should \'maixpy_bit\' button be displayed', async () => {
     await instance.selectMaixpyBitButton.waitForExist()
-    await expectWDIO(instance.selectMaixpyBitButton).toBeDisplayed()
+    await expect(instance.selectMaixpyBitButton).toBeDisplayed()
   })
 
   it('should \'maixpy_bit\' button have \'maixpy_bit\' text', async () => { 
     await instance.selectMaixpyBitText.waitForExist()
-    await expectWDIO(instance.selectMaixpyBitText).toHaveText('maixpy_bit')
+    await expect(instance.selectMaixpyBitText).toHaveText('maixpy_bit')
   })
 
   it('should \'maixpy_dock\' button be displayed', async () => {
     await instance.selectMaixpyDockButton.waitForExist()
-    await expectWDIO(instance.selectMaixpyDockButton).toBeDisplayed()
+    await expect(instance.selectMaixpyDockButton).toBeDisplayed()
   })
 
   it('should \'maixpy_dock\' button have \'maixpy_dock\' text', async () => { 
     await instance.selectMaixpyDockText.waitForExist()
-    await expectWDIO(instance.selectMaixpyDockText).toHaveText('maixpy_dock')
+    await expect(instance.selectMaixpyDockText).toHaveText('maixpy_dock')
   })
 
   it('should \'back\' button be displayed', async () => {
     await instance.selectBackButton.waitForExist()
-    await expectWDIO(instance.selectBackButton).toBeDisplayed()
+    await expect(instance.selectBackButton).toBeDisplayed()
   })
 
   it('should \'back\' button have \'back\' text', async () => { 
     await instance.selectBackText.waitForExist()
-    await expectWDIO(instance.selectBackText).toHaveText('Back')
+    await expect(instance.selectBackText).toHaveText('Back')
   })
 })
diff --git a/test/e2e/specs/007.select-device-m5stickv.spec.ts b/test/e2e/specs/007.select-device-m5stickv.spec.mts
similarity index 80%
rename from test/e2e/specs/007.select-device-m5stickv.spec.ts
rename to test/e2e/specs/007.select-device-m5stickv.spec.mts
index 61c64a40..7186c68e 100644
--- a/test/e2e/specs/007.select-device-m5stickv.spec.ts
+++ b/test/e2e/specs/007.select-device-m5stickv.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectDevice page selects \'maixpy_m5stickv\' device', () => {
 
@@ -38,13 +38,13 @@ describe('KruxInstaller SelectDevice page selects \'maixpy_m5stickv\' device', (
 
   it('should change to Main page', async () => {
     await instance.selectDevicePage.waitForExist({ reverse: true })
-    await expectWDIO(instance.selectDevicePage).not.toBeDisplayed()
+    await expect(instance.selectDevicePage).not.toBeDisplayed()
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
   it('should \'Select device\' button changed its text to \'Device: maixpy_m5stickv\'', async () => {
-    await expectWDIO(instance.mainSelectDeviceText).toHaveText('Device: maixpy_m5stickv')
+    await expect(instance.mainSelectDeviceText).toHaveText('Device: maixpy_m5stickv')
   })
 
 })
diff --git a/test/e2e/specs/008.select-device-amigo-ips.spec.ts b/test/e2e/specs/008.select-device-amigo-ips.spec.mts
similarity index 80%
rename from test/e2e/specs/008.select-device-amigo-ips.spec.ts
rename to test/e2e/specs/008.select-device-amigo-ips.spec.mts
index b12f9659..1e50fcff 100644
--- a/test/e2e/specs/008.select-device-amigo-ips.spec.ts
+++ b/test/e2e/specs/008.select-device-amigo-ips.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectDevice page selects \'maixpy_amigo_ips\' device', () => {
 
@@ -38,13 +38,13 @@ describe('KruxInstaller SelectDevice page selects \'maixpy_amigo_ips\' device',
 
   it('should change to Main page', async () => {
     await instance.selectDevicePage.waitForExist({ reverse: true })
-    await expectWDIO(instance.selectDevicePage).not.toBeDisplayed()
+    await expect(instance.selectDevicePage).not.toBeDisplayed()
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
   it('should \'Select device\' button changed its text to \'Device: maixpy_amigo_ips\'', async () => {
-    await expectWDIO(instance.mainSelectDeviceText).toHaveText('Device: maixpy_amigo_ips')
+    await expect(instance.mainSelectDeviceText).toHaveText('Device: maixpy_amigo_ips')
   })
 
 })
diff --git a/test/e2e/specs/009.select-device-amigo-tft.spec.ts b/test/e2e/specs/009.select-device-amigo-tft.spec.mts
similarity index 80%
rename from test/e2e/specs/009.select-device-amigo-tft.spec.ts
rename to test/e2e/specs/009.select-device-amigo-tft.spec.mts
index 6e1a1508..19c6a8d0 100644
--- a/test/e2e/specs/009.select-device-amigo-tft.spec.ts
+++ b/test/e2e/specs/009.select-device-amigo-tft.spec.mts
@@ -1,8 +1,9 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
+
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
-const App = require('../pageobjects/app.page')
 
 describe('KruxInstaller SelectDevice page selects \'maixpy_amigo_tft\' device', () => {
 
@@ -38,13 +39,13 @@ describe('KruxInstaller SelectDevice page selects \'maixpy_amigo_tft\' device',
 
   it('should change to Main page', async () => {
     await instance.selectDevicePage.waitForExist({ reverse: true })
-    await expectWDIO(instance.selectDevicePage).not.toBeDisplayed()
+    await expect(instance.selectDevicePage).not.toBeDisplayed()
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
   it('should \'Select device\' button changed its text to \'Device: maixpy_amigo_tft\'', async () => {
-    await expectWDIO(instance.mainSelectDeviceText).toHaveText('Device: maixpy_amigo_tft')
+    await expect(instance.mainSelectDeviceText).toHaveText('Device: maixpy_amigo_tft')
   })
 
 })
diff --git a/test/e2e/specs/010.select-device-bit.spec.ts b/test/e2e/specs/010.select-device-bit.spec.mts
similarity index 80%
rename from test/e2e/specs/010.select-device-bit.spec.ts
rename to test/e2e/specs/010.select-device-bit.spec.mts
index 5a110390..7977c500 100644
--- a/test/e2e/specs/010.select-device-bit.spec.ts
+++ b/test/e2e/specs/010.select-device-bit.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectDevice page selects \'maixpy_bit\' device', () => {
 
@@ -38,13 +38,13 @@ describe('KruxInstaller SelectDevice page selects \'maixpy_bit\' device', () =>
 
   it('should change to Main page', async () => {
     await instance.selectDevicePage.waitForExist({ reverse: true })
-    await expectWDIO(instance.selectDevicePage).not.toBeDisplayed()
+    await expect(instance.selectDevicePage).not.toBeDisplayed()
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
   it('should \'Select device\' button changed its text to \'Device: maixpy_bit\'', async () => {
-    await expectWDIO(instance.mainSelectDeviceText).toHaveText('Device: maixpy_bit')
+    await expect(instance.mainSelectDeviceText).toHaveText('Device: maixpy_bit')
   })
 
 })
diff --git a/test/e2e/specs/011.select-device-dock.spec.ts b/test/e2e/specs/011.select-device-dock.spec.mts
similarity index 80%
rename from test/e2e/specs/011.select-device-dock.spec.ts
rename to test/e2e/specs/011.select-device-dock.spec.mts
index 7770f21a..986fbbef 100644
--- a/test/e2e/specs/011.select-device-dock.spec.ts
+++ b/test/e2e/specs/011.select-device-dock.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectDevice page selects \'maixpy_dock\' device', () => {
 
@@ -38,13 +38,13 @@ describe('KruxInstaller SelectDevice page selects \'maixpy_dock\' device', () =>
 
   it('should change to Main page', async () => {
     await instance.selectDevicePage.waitForExist({ reverse: true })
-    await expectWDIO(instance.selectDevicePage).not.toBeDisplayed()
+    await expect(instance.selectDevicePage).not.toBeDisplayed()
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
   it('should \'Select device\' button changed its text to \'Device: maixpy_dock\'', async () => {
-    await expectWDIO(instance.mainSelectDeviceText).toHaveText('Device: maixpy_dock')
+    await expect(instance.mainSelectDeviceText).toHaveText('Device: maixpy_dock')
   })
 
 })
\ No newline at end of file
diff --git a/test/e2e/specs/012.select-device-back.spec.ts b/test/e2e/specs/012.select-device-back.spec.mts
similarity index 80%
rename from test/e2e/specs/012.select-device-back.spec.ts
rename to test/e2e/specs/012.select-device-back.spec.mts
index b4ffadb3..8442f1cd 100644
--- a/test/e2e/specs/012.select-device-back.spec.ts
+++ b/test/e2e/specs/012.select-device-back.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectDevice page selects \'back\' button', () => {
 
@@ -38,13 +38,13 @@ describe('KruxInstaller SelectDevice page selects \'back\' button', () => {
 
   it('should change to Main page', async () => {
     await instance.selectDevicePage.waitForExist({ reverse: true })
-    await expectWDIO(instance.selectDevicePage).not.toBeDisplayed()
+    await expect(instance.selectDevicePage).not.toBeDisplayed()
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
   it('should \'Select device\' button mantain its text to \'Select device\'', async () => {
-    await expectWDIO(instance.mainSelectDeviceText).toHaveText('Select device')
+    await expect(instance.mainSelectDeviceText).toHaveText('Select device')
   })
 
 })
diff --git a/test/e2e/specs/013.select-version-show-only.spec.ts b/test/e2e/specs/013.select-version-show-only.spec.mts
similarity index 72%
rename from test/e2e/specs/013.select-version-show-only.spec.ts
rename to test/e2e/specs/013.select-version-show-only.spec.mts
index 67876d8b..fd793e80 100644
--- a/test/e2e/specs/013.select-version-show-only.spec.ts
+++ b/test/e2e/specs/013.select-version-show-only.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 const GITHUB_OCTOCAT = [ 
     "MMM.           .MMM        ",
@@ -63,32 +63,32 @@ describe('KruxInstaller SelectVersion page (show only)', () => {
 
   it('should github\'s ocotcat checker appears', async () => { 
     await instance.githubOctocatCheckerLogo.waitForExist({ timeout: 3000 })
-    await expectWDIO(instance.githubOctocatCheckerLogo).toBeDisplayed()
-    await expectWDIO(instance.githubOctocatCheckerLogo).toHaveText(GITHUB_OCTOCAT)
+    await expect(instance.githubOctocatCheckerLogo).toBeDisplayed()
+    await expect(instance.githubOctocatCheckerLogo).toHaveText(GITHUB_OCTOCAT)
   })
 
   it('should \'Select version\' page appear', async () => {
     await instance.selectVersionPage.waitForExist()
-    await expectWDIO(instance.selectVersionPage).toBeDisplayed()
+    await expect(instance.selectVersionPage).toBeDisplayed()
   })
   
-  it('should \'selfcustody/krux/releases/tag/v23.09.0\' button appear', async () => {
+  it('should \'selfcustody/krux/releases/tag/v23.09.1\' button appear', async () => {
     await instance.selectVersionSelfcustodyButton.waitForExist()
-    await expectWDIO(instance.selectVersionSelfcustodyButton).toBeDisplayed()
+    await expect(instance.selectVersionSelfcustodyButton).toBeDisplayed()
   })
 
-  it('should \'selfcustody/krux/releases/tag/v23.09.0\' button have \'selfcustody/krux/releases/tag/v23.09.0\' text', async () => {
+  it('should \'selfcustody/krux/releases/tag/v23.09.1\' button have \'selfcustody/krux/releases/tag/v23.09.1\' text', async () => {
     await instance.selectVersionSelfcustodyText.waitForExist()
-    await expectWDIO(instance.selectVersionSelfcustodyText).toHaveText('selfcustody/krux/releases/tag/v23.09.0')
+    await expect(instance.selectVersionSelfcustodyText).toHaveText('selfcustody/krux/releases/tag/v23.09.1')
   })
 
   it('should \'odudex/krux_binaries\' button appear', async () => {
     await instance.selectVersionOdudexButton.waitForExist()
-    await expectWDIO(instance.selectVersionOdudexButton).toBeDisplayed()
+    await expect(instance.selectVersionOdudexButton).toBeDisplayed()
   })
 
-  it('should \'selfcustody/krux/releases/tag/v22.08.2\' button have \'selfcustody/krux/releases/tag/v22.08.2\' text', async () => {
+  it('should \'selfcustody/krux/releases/tag/v23.09.1\' button have \'selfcustody/krux/releases/tag/v23.09.1\' text', async () => {
     await instance.selectVersionOdudexText.waitForExist()
-    await expectWDIO(instance.selectVersionOdudexText).toHaveText('odudex/krux_binaries')
+    await expect(instance.selectVersionOdudexText).toHaveText('odudex/krux_binaries')
   })
 })
diff --git a/test/e2e/specs/014.select-version-selfcustody-release-zip.spec.ts b/test/e2e/specs/014.select-version-selfcustody-release-zip.spec.mts
similarity index 66%
rename from test/e2e/specs/014.select-version-selfcustody-release-zip.spec.ts
rename to test/e2e/specs/014.select-version-selfcustody-release-zip.spec.mts
index da1abd68..943c8825 100644
--- a/test/e2e/specs/014.select-version-selfcustody-release-zip.spec.ts
+++ b/test/e2e/specs/014.select-version-selfcustody-release-zip.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (download release)', () => {
 
@@ -39,48 +39,48 @@ describe('KruxInstaller SelectVersion page (download release)', () => {
     await instance.selectVersionOdudexText.waitForExist()
   })
 
-  it('should click on \'selfcustody/krux/tags/v23.09.0\' and go to ConsoleLoad page', async () => {
+  it('should click on \'selfcustody/krux/tags/v23.09.1\' and go to ConsoleLoad page', async () => {
     await instance.selectVersionSelfcustodyButton.click()
     await instance.selectVersionPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.selectVersionPage).not.toBeDisplayed()
+    await expect(instance.selectVersionPage).not.toBeDisplayed()
   })
 
-  it('should \'Checking v23.09.0/krux-v23.09.0.zip\' message appears', async () => {
+  it('should \'Checking v23.09.1/krux-v23.09.1.zip\' message appears', async () => {
     await instance.checkingReleaseZipMsg.waitForExist()
-    await expectWDIO(instance.checkingReleaseZipMsg).toBeDisplayed()
-    await expectWDIO(instance.checkingReleaseZipMsg).toHaveText('Checking v23.09.0/krux-v23.09.0.zip')
+    await expect(instance.checkingReleaseZipMsg).toBeDisplayed()
+    await expect(instance.checkingReleaseZipMsg).toHaveText('Checking v23.09.1/krux-v23.09.1.zip')
   })
 
-  it('should \'v23.09.0/krux-v23.09.0.zip not found\' message appears', async () => {
+  it('should \'v23.09.1/krux-v23.09.1.zip not found\' message appears', async () => {
     await instance.notFoundReleaseZipMsg.waitForExist()
-    await expectWDIO(instance.notFoundReleaseZipMsg).toBeDisplayed()
+    await expect(instance.notFoundReleaseZipMsg).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.notFoundReleaseZipMsg).toHaveText('v23.09.0/krux-v23.09.0.zip not found')
+      await expect(instance.notFoundReleaseZipMsg).toHaveText('v23.09.1/krux-v23.09.1.zip not found')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.notFoundReleaseZipMsg).toHaveText('v23.09.0\\krux-v23.09.0.zip not found')
+      await expect(instance.notFoundReleaseZipMsg).toHaveText('v23.09.1\\krux-v23.09.1.zip not found')
     }
   })
 
   it('should go to DownloadOfficialReleaseZip page', async () => {
     await instance.downloadOfficialReleaseZipPage.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipPage).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipPage).toBeDisplayed()
   })
 
   it('should DownloadOfficialReleaseZip page have \'Downloading\' title', async () => {
     await instance.downloadOfficialReleaseZipTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipTitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipTitle).toHaveText('Downloading')
+    await expect(instance.downloadOfficialReleaseZipTitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipTitle).toHaveText('Downloading')
   })
 
-  it('should DownloadOfficialReleaseZip page have \'https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip\' subtitle', async () => {
+  it('should DownloadOfficialReleaseZip page have \'https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip\' subtitle', async () => {
     await instance.downloadOfficialReleaseZipTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSubtitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip')
+    await expect(instance.downloadOfficialReleaseZipSubtitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip')
   })
 
   it('should DownloadOfficialReleaseZip page progress until 100%', async () => {
     await instance.downloadOfficialReleaseZipProgress.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipProgress).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipProgress).toBeDisplayed()
     await instance.downloadOfficialReleaseZipProgress.waitUntil(async function () {
       const percentText = await this.getText()
       const percent = parseFloat(percentText.split('%')[0])
diff --git a/test/e2e/specs/015.already-downloaded-selfcustody-release-zip.spec.ts b/test/e2e/specs/015.already-downloaded-selfcustody-release-zip.spec.mts
similarity index 63%
rename from test/e2e/specs/015.already-downloaded-selfcustody-release-zip.spec.ts
rename to test/e2e/specs/015.already-downloaded-selfcustody-release-zip.spec.mts
index 0d785314..15f8e1cc 100644
--- a/test/e2e/specs/015.already-downloaded-selfcustody-release-zip.spec.ts
+++ b/test/e2e/specs/015.already-downloaded-selfcustody-release-zip.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release - show only)', () => {
 
@@ -42,61 +42,61 @@ describe('KruxInstaller SelectVersion page (already downloaded release - show on
     await instance.checkingReleaseZipMsg.waitForExist()
   })
 
-  it('should \'v23.09.0/krux-v23.09.0.zip found\' message appears', async () => {
+  it('should \'v23.09.1/krux-v23.09.1.zip found\' message appears', async () => {
     await instance.foundReleaseZipMsg.waitForExist()
-    await expectWDIO(instance.foundReleaseZipMsg).toBeDisplayed()
+    await expect(instance.foundReleaseZipMsg).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.foundReleaseZipMsg).toHaveText('v23.09.0/krux-v23.09.0.zip found')
+      await expect(instance.foundReleaseZipMsg).toHaveText('v23.09.1/krux-v23.09.1.zip found')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.foundReleaseZipMsg).toHaveText('v23.09.0\\krux-v23.09.0.zip found')
+      await expect(instance.foundReleaseZipMsg).toHaveText('v23.09.1\\krux-v23.09.1.zip found')
     }
   })
 
   it('should WarningDownload page should be displayed', async () => {
     await instance.warningDownloadPage.waitForExist()
-    await expectWDIO(instance.warningDownloadPage).toBeDisplayed()
+    await expect(instance.warningDownloadPage).toBeDisplayed()
   }) 
 
-  it('should \'v23.09.0/krux-v23.09.0.zip already downloaded\' message be displayed', async () => {
+  it('should \'v23.09.1/krux-v23.09.1.zip already downloaded\' message be displayed', async () => {
     await instance.warningAlreadyDownloadedText.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedText).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedText).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.warningAlreadyDownloadedText).toHaveText('v23.09.0/krux-v23.09.0.zip already downloaded')
+      await expect(instance.warningAlreadyDownloadedText).toHaveText('v23.09.1/krux-v23.09.1.zip already downloaded')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.warningAlreadyDownloadedText).toHaveText('v23.09.0\\krux-v23.09.0.zip already downloaded')
+      await expect(instance.warningAlreadyDownloadedText).toHaveText('v23.09.1\\krux-v23.09.1.zip already downloaded')
     }
   })
 
   it('should \'Proceed with current file\' button be displayed', async () => {
     await instance.warningDownloadProceedButton.waitForExist()
     await instance.warningDownloadProceedButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadProceedButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadProceedButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadProceedButtonText).toHaveText('Proceed with current file')
+    await expect(instance.warningDownloadProceedButton).toBeDisplayed()
+    await expect(instance.warningDownloadProceedButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadProceedButtonText).toHaveText('Proceed with current file')
   })
 
   it('should \'Download it again\' button be displayed', async () => {
     await instance.warningDownloadAgainButton.waitForExist()
     await instance.warningDownloadAgainButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadAgainButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadAgainButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadAgainButtonText).toHaveText('Download it again')
+    await expect(instance.warningDownloadAgainButton).toBeDisplayed()
+    await expect(instance.warningDownloadAgainButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadAgainButtonText).toHaveText('Download it again')
   })
 
   it('should \'Show details\' button be displayed', async () => {
     await instance.warningDownloadShowDetailsButton.waitForExist()
     await instance.warningDownloadShowDetailsButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadShowDetailsButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadShowDetailsButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadShowDetailsButtonText).toHaveText('Show details')
+    await expect(instance.warningDownloadShowDetailsButton).toBeDisplayed()
+    await expect(instance.warningDownloadShowDetailsButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadShowDetailsButtonText).toHaveText('Show details')
   })
 
   it('should \'Back\' button be displayed', async () => {
     await instance.warningDownloadBackButton.waitForExist()
     await instance.warningDownloadBackButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadBackButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadBackButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadBackButtonText).toHaveText('Back')
+    await expect(instance.warningDownloadBackButton).toBeDisplayed()
+    await expect(instance.warningDownloadBackButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadBackButtonText).toHaveText('Back')
   })
 
 })
diff --git a/test/e2e/specs/016.already-downloaded-selfcustody-release-zip-click-back-button.spec.ts b/test/e2e/specs/016.already-downloaded-selfcustody-release-zip-click-back-button.spec.mts
similarity index 84%
rename from test/e2e/specs/016.already-downloaded-selfcustody-release-zip-click-back-button.spec.ts
rename to test/e2e/specs/016.already-downloaded-selfcustody-release-zip-click-back-button.spec.mts
index c9a56c8d..dfe008d4 100644
--- a/test/e2e/specs/016.already-downloaded-selfcustody-release-zip-click-back-button.spec.ts
+++ b/test/e2e/specs/016.already-downloaded-selfcustody-release-zip-click-back-button.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release - click back button)', () => {
 
@@ -56,17 +56,17 @@ describe('KruxInstaller SelectVersion page (already downloaded release - click b
   it ('should click \'Back\' button and go out from WarningDownload page', async () => {
     await instance.warningDownloadBackButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
 
   it('should Main Page be displayed', async () => {
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
-  it('should \'Select version\' button changed to \'Version: selfcustody/krux/releases/tag/v23.09.0\'', async () => {
+  it('should \'Select version\' button changed to \'Version: selfcustody/krux/releases/tag/v23.09.1\'', async () => {
     await instance.mainSelectVersionText.waitForExist()
-    await expectWDIO(instance.mainSelectVersionText).toBeDisplayed()
-    await expectWDIO(instance.mainSelectVersionText).toHaveText('Version: selfcustody/krux/releases/tag/v23.09.0')
+    await expect(instance.mainSelectVersionText).toBeDisplayed()
+    await expect(instance.mainSelectVersionText).toHaveText('Version: selfcustody/krux/releases/tag/v23.09.1')
   })
 })
diff --git a/test/e2e/specs/017.already-downloaded-selfcustody-release-zip-click-show-details-button.spec.ts b/test/e2e/specs/017.already-downloaded-selfcustody-release-zip-click-show-details-button.spec.mts
similarity index 69%
rename from test/e2e/specs/017.already-downloaded-selfcustody-release-zip-click-show-details-button.spec.ts
rename to test/e2e/specs/017.already-downloaded-selfcustody-release-zip-click-show-details-button.spec.mts
index 7978a514..f669d605 100644
--- a/test/e2e/specs/017.already-downloaded-selfcustody-release-zip-click-show-details-button.spec.ts
+++ b/test/e2e/specs/017.already-downloaded-selfcustody-release-zip-click-show-details-button.spec.mts
@@ -1,10 +1,11 @@
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { join } from 'path'
+import { homedir } from 'os'
+import { osLangSync } from 'os-lang'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release - click show details button)', () => {
 
@@ -56,36 +57,36 @@ describe('KruxInstaller SelectVersion page (already downloaded release - click s
   })
 
   it ('should overlay not be shown', async () => {
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
   })
 
   it ('should click \'Show details\' button and overlay must be visible', async () => {
     await instance.warningDownloadShowDetailsButton.click()
     await instance.warningAlreadyDownloadedOverlay.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).toBeDisplayed()
   })
 
   it ('should overlay title be \'Resource details\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTitle.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTitle).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTitle).toHaveText('Resource details')
+    await expect(instance.warningAlreadyDownloadedOverlayTitle).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTitle).toHaveText('Resource details')
   })
 
-  it ('should overlay subtitle be \'v23.09.0/krux-v23.09.0.zip\'', async () => {
+  it ('should overlay subtitle be \'v23.09.1/krux-v23.09.1.zip\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTitle.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlaySubtitle).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlaySubtitle).toHaveText('v23.09.0/krux-v23.09.0.zip')
+    await expect(instance.warningAlreadyDownloadedOverlaySubtitle).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlaySubtitle).toHaveText('v23.09.1/krux-v23.09.1.zip')
   })
 
-  it ('should a overlay text have \'Remote: https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip\'', async () => {
+  it ('should a overlay text have \'Remote: https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTextRemote.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextRemote).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextRemote).toHaveText('Remote:\nhttps://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip')
+    await expect(instance.warningAlreadyDownloadedOverlayTextRemote).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextRemote).toHaveText('Remote:\nhttps://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip')
   })
 
   it ('should a overlay text have properly local resource', async () => {
     await instance.warningAlreadyDownloadedOverlayTextLocal.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextLocal).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextLocal).toBeDisplayed()
     
     let resources = ''
     if (process.env.CI && process.env.GITHUB_ACTION) {
@@ -108,26 +109,26 @@ describe('KruxInstaller SelectVersion page (already downloaded release - click s
       }
     }
 
-    const resource = join(resources, 'v23.09.0', 'krux-v23.09.0.zip')
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextLocal).toHaveText(`Local:\n${resource}`)
+    const resource = join(resources, 'v23.09.1', 'krux-v23.09.1.zip')
+    await expect(instance.warningAlreadyDownloadedOverlayTextLocal).toHaveText(`Local:\n${resource}`)
   })
 
   it('should a overlay text have the properly description', async () => {
     await instance.warningAlreadyDownloadedOverlayTextWhatdo.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextWhatdo).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextWhatdo).toHaveText('Description:\nThis file is the official release with all necessary contents to flash or update krux firmware on your Kendryte K210 device, including the firmware signature that prove the firmware\'s authenticity')
+    await expect(instance.warningAlreadyDownloadedOverlayTextWhatdo).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextWhatdo).toHaveText('Description:\nThis file is the official release with all necessary contents to flash or update krux firmware on your Kendryte K210 device, including the firmware signature that prove the firmware\'s authenticity')
   })
 
   it('should \'close\' have \'Close\' text',async () => {
     await instance.warningAlreadyDownloadedOverlayButtonClose.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayButtonClose).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayButtonClose).toHaveText('Close')
+    await expect(instance.warningAlreadyDownloadedOverlayButtonClose).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayButtonClose).toHaveText('Close')
   })
 
   it('should \'close\' button make overlay not visible', async () => {
     await instance.warningAlreadyDownloadedOverlayButtonClose.click()
     await instance.warningAlreadyDownloadedOverlay.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
   })
   
 })
diff --git a/test/e2e/specs/018.already-downloaded-selfcustody-release-zip-click-download-again.spec.ts b/test/e2e/specs/018.already-downloaded-selfcustody-release-zip-click-download-again.spec.mts
similarity index 79%
rename from test/e2e/specs/018.already-downloaded-selfcustody-release-zip-click-download-again.spec.ts
rename to test/e2e/specs/018.already-downloaded-selfcustody-release-zip-click-download-again.spec.mts
index cb99754b..e14752fa 100644
--- a/test/e2e/specs/018.already-downloaded-selfcustody-release-zip-click-download-again.spec.ts
+++ b/test/e2e/specs/018.already-downloaded-selfcustody-release-zip-click-download-again.spec.mts
@@ -1,10 +1,8 @@
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release - click download again button)', () => {
 
@@ -58,29 +56,29 @@ describe('KruxInstaller SelectVersion page (already downloaded release - click d
   it ('should click \'Download again\' go out of WarningDownload page', async () => {
     await instance.warningDownloadAgainButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
 
   it ('should be in DownloadOfficialRelease page', async () => {
     await instance.downloadOfficialReleaseZipPage.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipPage).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipPage).toBeDisplayed()
   })
 
   it('should DownloadOfficialReleaseZip page have \'Downloading\' title', async () => {
     await instance.downloadOfficialReleaseZipTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipTitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipTitle).toHaveText('Downloading')
+    await expect(instance.downloadOfficialReleaseZipTitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipTitle).toHaveText('Downloading')
   })
 
-  it('should DownloadOfficialReleaseZip page have \'https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip\' subtitle', async () => {
+  it('should DownloadOfficialReleaseZip page have \'https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip\' subtitle', async () => {
     await instance.downloadOfficialReleaseZipTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSubtitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip')
+    await expect(instance.downloadOfficialReleaseZipSubtitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip')
   })
 
   it('should DownloadOfficialReleaseZip page progress until 100%', async () => {
     await instance.downloadOfficialReleaseZipProgress.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipProgress).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipProgress).toBeDisplayed()
     await instance.downloadOfficialReleaseZipProgress.waitUntil(async function () {
       const percentText = await this.getText()
       const percent = parseFloat(percentText.split('%')[0])
diff --git a/test/e2e/specs/019.already-downloaded-selfcustody-release-zip-click-proceed-button.spec.ts b/test/e2e/specs/019.already-downloaded-selfcustody-release-zip-click-proceed-button.spec.mts
similarity index 89%
rename from test/e2e/specs/019.already-downloaded-selfcustody-release-zip-click-proceed-button.spec.ts
rename to test/e2e/specs/019.already-downloaded-selfcustody-release-zip-click-proceed-button.spec.mts
index 150ed964..a3452561 100644
--- a/test/e2e/specs/019.already-downloaded-selfcustody-release-zip-click-proceed-button.spec.ts
+++ b/test/e2e/specs/019.already-downloaded-selfcustody-release-zip-click-proceed-button.spec.mts
@@ -1,10 +1,8 @@
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release - click proceed button)', () => {
 
@@ -58,7 +56,7 @@ describe('KruxInstaller SelectVersion page (already downloaded release - click p
   it ('should click \'Proceed\' button and go out of WarningDownload page', async () => {
     await instance.warningDownloadProceedButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
   
 })
diff --git a/test/e2e/specs/020.select-version-selfcustody-release-zip-sha256.spec.ts b/test/e2e/specs/020.select-version-selfcustody-release-zip-sha256.spec.mts
similarity index 74%
rename from test/e2e/specs/020.select-version-selfcustody-release-zip-sha256.spec.ts
rename to test/e2e/specs/020.select-version-selfcustody-release-zip-sha256.spec.mts
index e188c29e..59b8d795 100644
--- a/test/e2e/specs/020.select-version-selfcustody-release-zip-sha256.spec.ts
+++ b/test/e2e/specs/020.select-version-selfcustody-release-zip-sha256.spec.mts
@@ -1,10 +1,9 @@
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
+
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
-const App = require('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (download release sha256.txt)', () => {
 
@@ -57,36 +56,36 @@ describe('KruxInstaller SelectVersion page (download release sha256.txt)', () =>
     await instance.warningDownloadPage.waitForExist({ reverse: true })
   })
 
-  it ('should \'checking v23.09.0/krux-v23.09.0.zip.sha256.txt\' message appears', async () => {
+  it ('should \'checking v23.09.1/krux-v23.09.1.zip.sha256.txt\' message appears', async () => {
     await instance.checkingReleaseZipSha256txtMsg.waitForExist()
-    await expectWDIO(instance.checkingReleaseZipSha256txtMsg).toBeDisplayed()
+    await expect(instance.checkingReleaseZipSha256txtMsg).toBeDisplayed()
   })
 
-  it ('should \'v23.09.0/krux-v23.09.0.zip.sha256.txt not found\' message appears', async () => {
+  it ('should \'v23.09.1/krux-v23.09.1.zip.sha256.txt not found\' message appears', async () => {
     await instance.notFoundReleaseZipSha256txtMsg.waitForExist()
-    await expectWDIO(instance.notFoundReleaseZipSha256txtMsg).toBeDisplayed()
+    await expect(instance.notFoundReleaseZipSha256txtMsg).toBeDisplayed()
   })
 
   it('should go to DownloadOfficialReleaseZipSha256 page', async () => {
     await instance.downloadOfficialReleaseZipSha256txtPage.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPage).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSha256txtPage).toBeDisplayed()
   })
 
   it('should DownloadOfficialReleaseZipSha256 page have \'Downloading\' title', async () => {
     await instance.downloadOfficialReleaseZipSha256txtPageTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageTitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageTitle).toHaveText('Downloading')
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageTitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageTitle).toHaveText('Downloading')
   })
 
-  it('should DownloadOfficialReleaseZipSha256 page have \'https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sha256.txt\' subtitle', async () => {
+  it('should DownloadOfficialReleaseZipSha256 page have \'https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sha256.txt\' subtitle', async () => {
     await instance.downloadOfficialReleaseZipSha256txtPageSubtitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageSubtitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sha256.txt')
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageSubtitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sha256.txt')
   })
 
   it('should DownloadOfficialReleaseZipSha256 page progress until 100%', async () => {
     await instance.downloadOfficialReleaseZipSha256txtPageProgress.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageProgress).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageProgress).toBeDisplayed()
     await instance.downloadOfficialReleaseZipSha256txtPageProgress.waitUntil(async function () {
       const percentText = await this.getText()
       const percent = parseFloat(percentText.split('%')[0])
diff --git a/test/e2e/specs/021.already-downloaded-selfcustody-release-zip-sha256.spec.ts b/test/e2e/specs/021.already-downloaded-selfcustody-release-zip-sha256.spec.mts
similarity index 67%
rename from test/e2e/specs/021.already-downloaded-selfcustody-release-zip-sha256.spec.ts
rename to test/e2e/specs/021.already-downloaded-selfcustody-release-zip-sha256.spec.mts
index b2912823..dee1e59d 100644
--- a/test/e2e/specs/021.already-downloaded-selfcustody-release-zip-sha256.spec.ts
+++ b/test/e2e/specs/021.already-downloaded-selfcustody-release-zip-sha256.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release sha256.txt - show only)', () => {
 
@@ -54,61 +54,61 @@ describe('KruxInstaller SelectVersion page (already downloaded release sha256.tx
     await instance.warningDownloadPage.waitForExist({ reverse: true })
   })
 
-  it ('should \'v23.09.0/krux-v23.09.0.zip.sha256.txt found\' message appears', async () => {
+  it ('should \'v23.09.1/krux-v23.09.1.zip.sha256.txt found\' message appears', async () => {
     await instance.checkingReleaseZipSha256txtMsg.waitForExist()
-    await expectWDIO(instance.checkingReleaseZipSha256txtMsg).toBeDisplayed()
+    await expect(instance.checkingReleaseZipSha256txtMsg).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.foundReleaseZipSha256txtMsg).toHaveText('v23.09.0/krux-v23.09.0.zip.sha256.txt found')
+      await expect(instance.foundReleaseZipSha256txtMsg).toHaveText('v23.09.1/krux-v23.09.1.zip.sha256.txt found')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.foundReleaseZipSha256txtMsg).toHaveText('v23.09.0\\krux-v23.09.0.zip.sha256.txt found')
+      await expect(instance.foundReleaseZipSha256txtMsg).toHaveText('v23.09.1\\krux-v23.09.1.zip.sha256.txt found')
     }
   })
 
   it('should WarningDownload page should be displayed', async () => {
     await instance.warningDownloadPage.waitForExist()
-    await expectWDIO(instance.warningDownloadPage).toBeDisplayed()
+    await expect(instance.warningDownloadPage).toBeDisplayed()
   }) 
 
-  it('should \'v23.09.0/krux-v23.09.0.zip.sha256.txt already downloaded\' message be displayed', async () => {
+  it('should \'v23.09.1/krux-v23.09.1.zip.sha256.txt already downloaded\' message be displayed', async () => {
     await instance.warningAlreadyDownloadedText.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedText).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedText).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.warningAlreadyDownloadedText).toHaveText('v23.09.0/krux-v23.09.0.zip.sha256.txt already downloaded')
+      await expect(instance.warningAlreadyDownloadedText).toHaveText('v23.09.1/krux-v23.09.1.zip.sha256.txt already downloaded')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.warningAlreadyDownloadedText).toHaveText('v23.09.0\\krux-v23.09.0.zip.sha256.txt already downloaded')
+      await expect(instance.warningAlreadyDownloadedText).toHaveText('v23.09.1\\krux-v23.09.1.zip.sha256.txt already downloaded')
     }
   })
 
   it('should \'Proceed with current file\' button be displayed', async () => {
     await instance.warningDownloadProceedButton.waitForExist()
     await instance.warningDownloadProceedButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadProceedButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadProceedButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadProceedButtonText).toHaveText('Proceed with current file')
+    await expect(instance.warningDownloadProceedButton).toBeDisplayed()
+    await expect(instance.warningDownloadProceedButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadProceedButtonText).toHaveText('Proceed with current file')
   })
 
   it('should \'Download it again\' button be displayed', async () => {
     await instance.warningDownloadAgainButton.waitForExist()
     await instance.warningDownloadAgainButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadAgainButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadAgainButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadAgainButtonText).toHaveText('Download it again')
+    await expect(instance.warningDownloadAgainButton).toBeDisplayed()
+    await expect(instance.warningDownloadAgainButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadAgainButtonText).toHaveText('Download it again')
   })
 
   it('should \'Show details\' button be displayed', async () => {
     await instance.warningDownloadShowDetailsButton.waitForExist()
     await instance.warningDownloadShowDetailsButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadShowDetailsButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadShowDetailsButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadShowDetailsButtonText).toHaveText('Show details')
+    await expect(instance.warningDownloadShowDetailsButton).toBeDisplayed()
+    await expect(instance.warningDownloadShowDetailsButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadShowDetailsButtonText).toHaveText('Show details')
   })
 
   it('should \'Back\' button be displayed', async () => {
     await instance.warningDownloadBackButton.waitForExist()
     await instance.warningDownloadBackButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadBackButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadBackButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadBackButtonText).toHaveText('Back')
+    await expect(instance.warningDownloadBackButton).toBeDisplayed()
+    await expect(instance.warningDownloadBackButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadBackButtonText).toHaveText('Back')
   })
 
 })
diff --git a/test/e2e/specs/022.already-downloaded-selfcustody-release-zip-sha256-click-back-button.spec.ts b/test/e2e/specs/022.already-downloaded-selfcustody-release-zip-sha256-click-back-button.spec.mts
similarity index 85%
rename from test/e2e/specs/022.already-downloaded-selfcustody-release-zip-sha256-click-back-button.spec.ts
rename to test/e2e/specs/022.already-downloaded-selfcustody-release-zip-sha256-click-back-button.spec.mts
index 426eb659..88de791f 100644
--- a/test/e2e/specs/022.already-downloaded-selfcustody-release-zip-sha256-click-back-button.spec.ts
+++ b/test/e2e/specs/022.already-downloaded-selfcustody-release-zip-sha256-click-back-button.spec.mts
@@ -1,8 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release sha256.txt - click back button)', () => {
 
@@ -62,18 +62,18 @@ describe('KruxInstaller SelectVersion page (already downloaded release sha256.tx
   it ('should click \'Back\' button and go out from WarningDownload page', async () => {
     await instance.warningDownloadBackButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
 
   it('should Main Page be displayed', async () => {
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   }) 
 
-  it('should \'Select version\' button changed to \'Version: selfcustody/krux/releases/tag/v23.09.0\'', async () => {
+  it('should \'Select version\' button changed to \'Version: selfcustody/krux/releases/tag/v23.09.1\'', async () => {
     await instance.mainSelectVersionText.waitForExist()
-    await expectWDIO(instance.mainSelectVersionText).toBeDisplayed()
-    await expectWDIO(instance.mainSelectVersionText).toHaveText('Version: selfcustody/krux/releases/tag/v23.09.0')
+    await expect(instance.mainSelectVersionText).toBeDisplayed()
+    await expect(instance.mainSelectVersionText).toHaveText('Version: selfcustody/krux/releases/tag/v23.09.1')
   })
 
 })
diff --git a/test/e2e/specs/023.already-downloaded-selfcustody-release-zip-sha256-click-show-details-button.spec.ts b/test/e2e/specs/023.already-downloaded-selfcustody-release-zip-sha256-click-show-details-button.spec.mts
similarity index 71%
rename from test/e2e/specs/023.already-downloaded-selfcustody-release-zip-sha256-click-show-details-button.spec.ts
rename to test/e2e/specs/023.already-downloaded-selfcustody-release-zip-sha256-click-show-details-button.spec.mts
index 8f7a0914..1e0a771a 100644
--- a/test/e2e/specs/023.already-downloaded-selfcustody-release-zip-sha256-click-show-details-button.spec.ts
+++ b/test/e2e/specs/023.already-downloaded-selfcustody-release-zip-sha256-click-show-details-button.spec.mts
@@ -1,11 +1,11 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { join } from 'path'
+import { homedir } from 'os'
+import { osLangSync } from 'os-lang'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release sha256.txt - click show details button)', () => {
 
@@ -63,36 +63,36 @@ describe('KruxInstaller SelectVersion page (already downloaded release sha256.tx
   })
 
   it ('should overlay not be shown', async () => {
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
   })
 
   it ('should click \'Show details\' button and overlay must be visible', async () => {
     await instance.warningDownloadShowDetailsButton.click()
     await instance.warningAlreadyDownloadedOverlay.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).toBeDisplayed()
   })
 
   it('should overlay title be \'Resource details\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTitle.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTitle).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTitle).toHaveText('Resource details')
+    await expect(instance.warningAlreadyDownloadedOverlayTitle).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTitle).toHaveText('Resource details')
   })
 
-  it ('should overlay subtitle be \'v23.09.0/krux-v23.09.0.zip.sha256.txt\'', async () => {
+  it ('should overlay subtitle be \'v23.09.1/krux-v23.09.1.zip.sha256.txt\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTitle.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlaySubtitle).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlaySubtitle).toHaveText('v23.09.0/krux-v23.09.0.zip.sha256.txt')
+    await expect(instance.warningAlreadyDownloadedOverlaySubtitle).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlaySubtitle).toHaveText('v23.09.1/krux-v23.09.1.zip.sha256.txt')
   })
 
-  it ('should a overlay text have \'Remote: https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sha256.txt\'', async () => {
+  it ('should a overlay text have \'Remote: https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sha256.txt\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTextRemote.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextRemote).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextRemote).toHaveText('Remote:\nhttps://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sha256.txt')
+    await expect(instance.warningAlreadyDownloadedOverlayTextRemote).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextRemote).toHaveText('Remote:\nhttps://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sha256.txt')
   })
 
   it ('should a overlay text have properly local resource', async () => {
     await instance.warningAlreadyDownloadedOverlayTextLocal.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextLocal).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextLocal).toBeDisplayed()
     
     let resources = ''
     if (process.env.CI && process.env.GITHUB_ACTION) {
@@ -115,26 +115,26 @@ describe('KruxInstaller SelectVersion page (already downloaded release sha256.tx
       }
     }
 
-    const resource = join(resources, 'v23.09.0', 'krux-v23.09.0.zip.sha256.txt')
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextLocal).toHaveText(`Local:\n${resource}`)
+    const resource = join(resources, 'v23.09.1', 'krux-v23.09.1.zip.sha256.txt')
+    await expect(instance.warningAlreadyDownloadedOverlayTextLocal).toHaveText(`Local:\n${resource}`)
   })
 
   it('should a overlay text have the properly description', async () => {
     await instance.warningAlreadyDownloadedOverlayTextWhatdo.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextWhatdo).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextWhatdo).toHaveText('Description:\nThis file proves the integrity of previous file. It uses the sha256 algorithm to check if zip file has not be changed during download.')
+    await expect(instance.warningAlreadyDownloadedOverlayTextWhatdo).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextWhatdo).toHaveText('Description:\nThis file proves the integrity of previous file. It uses the sha256 algorithm to check if zip file has not be changed during download.')
   })
 
   it('should \'close\' have \'Close\' text',async () => {
     await instance.warningAlreadyDownloadedOverlayButtonClose.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayButtonClose).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayButtonClose).toHaveText('Close')
+    await expect(instance.warningAlreadyDownloadedOverlayButtonClose).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayButtonClose).toHaveText('Close')
   })
 
   it('should \'close\' button make overlay not visible', async () => {
     await instance.warningAlreadyDownloadedOverlayButtonClose.click()
     await instance.warningAlreadyDownloadedOverlay.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
   })
   
 })
diff --git a/test/e2e/specs/024.already-downloaded-selfcustody-release-zip-sha256-click-download-again-button.spec.ts b/test/e2e/specs/024.already-downloaded-selfcustody-release-zip-sha256-click-download-again-button.spec.mts
similarity index 78%
rename from test/e2e/specs/024.already-downloaded-selfcustody-release-zip-sha256-click-download-again-button.spec.ts
rename to test/e2e/specs/024.already-downloaded-selfcustody-release-zip-sha256-click-download-again-button.spec.mts
index 016dadb1..5007eb3a 100644
--- a/test/e2e/specs/024.already-downloaded-selfcustody-release-zip-sha256-click-download-again-button.spec.ts
+++ b/test/e2e/specs/024.already-downloaded-selfcustody-release-zip-sha256-click-download-again-button.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release sha256.txt - click download again button)', () => {
 
@@ -66,29 +63,29 @@ describe('KruxInstaller SelectVersion page (already downloaded release sha256.tx
   it ('should click \'Download again\' go out of WarningDownload page', async () => {
     await instance.warningDownloadAgainButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
 
   it ('should be in DownloadOfficialReleaseZipSha256 page', async () => {
     await instance.downloadOfficialReleaseZipSha256txtPage.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPage).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSha256txtPage).toBeDisplayed()
   })
 
   it('should DownloadOfficialReleaseZipSha256 page have \'Downloading\' title', async () => {
     await instance.downloadOfficialReleaseZipSha256txtPageTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageTitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageTitle).toHaveText('Downloading')
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageTitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageTitle).toHaveText('Downloading')
   })
 
-  it('should DownloadOfficialReleaseZipSha256 page have \'https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sha256.txt\' subtitle', async () => {
+  it('should DownloadOfficialReleaseZipSha256 page have \'https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sha256.txt\' subtitle', async () => {
     await instance.downloadOfficialReleaseZipSha256txtPageSubtitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageSubtitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sha256.txt')
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageSubtitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sha256.txt')
   })
 
   it('should DownloadOfficialReleaseZipSha256 page progress until 100%', async () => {
     await instance.downloadOfficialReleaseZipSha256txtPageProgress.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSha256txtPageProgress).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSha256txtPageProgress).toBeDisplayed()
     await instance.downloadOfficialReleaseZipSha256txtPageProgress.waitUntil(async function () {
       const percentText = await this.getText()
       const percent = parseFloat(percentText.split('%')[0])
diff --git a/test/e2e/specs/025.already-downloaded-selfcustody-release-zip-sha256-click-proceed-button.spec.ts b/test/e2e/specs/025.already-downloaded-selfcustody-release-zip-sha256-click-proceed-button.spec.mts
similarity index 89%
rename from test/e2e/specs/025.already-downloaded-selfcustody-release-zip-sha256-click-proceed-button.spec.ts
rename to test/e2e/specs/025.already-downloaded-selfcustody-release-zip-sha256-click-proceed-button.spec.mts
index 50216b23..bb848130 100644
--- a/test/e2e/specs/025.already-downloaded-selfcustody-release-zip-sha256-click-proceed-button.spec.ts
+++ b/test/e2e/specs/025.already-downloaded-selfcustody-release-zip-sha256-click-proceed-button.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release sha256.txt - click  proceed button)', () => {
 
@@ -66,7 +63,7 @@ describe('KruxInstaller SelectVersion page (already downloaded release sha256.tx
   it ('should click \'Proceed\' go out of WarningDownload page', async () => {
     await instance.warningDownloadProceedButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
   
 })
diff --git a/test/e2e/specs/026.select-version-selfcustody-release-zip-sig.spec.ts b/test/e2e/specs/026.select-version-selfcustody-release-zip-sig.spec.mts
similarity index 76%
rename from test/e2e/specs/026.select-version-selfcustody-release-zip-sig.spec.ts
rename to test/e2e/specs/026.select-version-selfcustody-release-zip-sig.spec.mts
index 225cdb79..2706f0d1 100644
--- a/test/e2e/specs/026.select-version-selfcustody-release-zip-sig.spec.ts
+++ b/test/e2e/specs/026.select-version-selfcustody-release-zip-sig.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (download release signature)', () => {
 
@@ -65,36 +62,36 @@ describe('KruxInstaller SelectVersion page (download release signature)', () =>
     await instance.warningDownloadPage.waitForExist({ reverse: true })
   })
 
-  it ('should \'checking v23.09.0/krux-v23.09.0.zip.sig\' message appears', async () => {
+  it ('should \'checking v23.09.1/krux-v23.09.1.zip.sig\' message appears', async () => {
     await instance.checkingReleaseZipSigMsg.waitForExist()
-    await expectWDIO(instance.checkingReleaseZipSigMsg).toBeDisplayed()
+    await expect(instance.checkingReleaseZipSigMsg).toBeDisplayed()
   })
 
-  it ('should \'v23.09.0/krux-v23.09.0.zip.sig not found\' message appears', async () => {
+  it ('should \'v23.09.1/krux-v23.09.1.zip.sig not found\' message appears', async () => {
     await instance.notFoundReleaseZipSigMsg.waitForExist()
-    await expectWDIO(instance.notFoundReleaseZipSigMsg).toBeDisplayed()
+    await expect(instance.notFoundReleaseZipSigMsg).toBeDisplayed()
   })
 
   it('should go to DownloadOfficialReleaseZipSig page', async () => {
     await instance.downloadOfficialReleaseZipSigPage.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigPage).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSigPage).toBeDisplayed()
   })
 
   it('should DownloadOfficialReleaseZipSig page have \'Downloading\' title', async () => {
     await instance.downloadOfficialReleaseZipSigTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigTitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigTitle).toHaveText('Downloading')
+    await expect(instance.downloadOfficialReleaseZipSigTitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSigTitle).toHaveText('Downloading')
   })
 
-  it('should DownloadOfficialReleaseZipSig page have \'https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sig\' subtitle', async () => {
+  it('should DownloadOfficialReleaseZipSig page have \'https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sig\' subtitle', async () => {
     await instance.downloadOfficialReleaseZipSigSubtitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigSubtitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sig')
+    await expect(instance.downloadOfficialReleaseZipSigSubtitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSigSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sig')
   })
 
   it('should DownloadOfficialReleaseZipSig page progress until 100%', async () => {
     await instance.downloadOfficialReleaseZipSigProgress.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigProgress).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSigProgress).toBeDisplayed()
     await instance.downloadOfficialReleaseZipSigProgress.waitUntil(async function () {
       const percentText = await this.getText()
       const percent = parseFloat(percentText.split('%')[0])
diff --git a/test/e2e/specs/027.already-downloaded-selfcustody-release-zip-sig.spec.ts b/test/e2e/specs/027.already-downloaded-selfcustody-release-zip-sig.spec.mts
similarity index 69%
rename from test/e2e/specs/027.already-downloaded-selfcustody-release-zip-sig.spec.ts
rename to test/e2e/specs/027.already-downloaded-selfcustody-release-zip-sig.spec.mts
index 1a512372..8599c843 100644
--- a/test/e2e/specs/027.already-downloaded-selfcustody-release-zip-sig.spec.ts
+++ b/test/e2e/specs/027.already-downloaded-selfcustody-release-zip-sig.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded  release signature - show only)', () => {
 
@@ -65,61 +62,61 @@ describe('KruxInstaller SelectVersion page (already downloaded  release signatur
     await instance.warningDownloadPage.waitForExist({ reverse: true })
   })
 
-  it ('should \'v23.09.0/krux-v23.09.0.zip.sig found\' message appears', async () => {
+  it ('should \'v23.09.1/krux-v23.09.1.zip.sig found\' message appears', async () => {
     await instance.checkingReleaseZipSigMsg.waitForExist()
-    await expectWDIO(instance.foundReleaseZipSigMsg).toBeDisplayed()
+    await expect(instance.foundReleaseZipSigMsg).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.foundReleaseZipSigMsg).toHaveText('v23.09.0/krux-v23.09.0.zip.sig found')
+      await expect(instance.foundReleaseZipSigMsg).toHaveText('v23.09.1/krux-v23.09.1.zip.sig found')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.foundReleaseZipSigMsg).toHaveText('v23.09.0\\krux-v23.09.0.zip.sig found')
+      await expect(instance.foundReleaseZipSigMsg).toHaveText('v23.09.1\\krux-v23.09.1.zip.sig found')
     }
   })
 
   it('should WarningDownload page should be displayed', async () => {
     await instance.warningDownloadPage.waitForExist()
-    await expectWDIO(instance.warningDownloadPage).toBeDisplayed()
+    await expect(instance.warningDownloadPage).toBeDisplayed()
   }) 
 
-  it('should \'v23.09.0/krux-v23.09.0.zip.sig already downloaded\' message be displayed', async () => {
+  it('should \'v23.09.1/krux-v23.09.1.zip.sig already downloaded\' message be displayed', async () => {
     await instance.warningAlreadyDownloadedText.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedText).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedText).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.warningAlreadyDownloadedText).toHaveText('v23.09.0/krux-v23.09.0.zip.sig already downloaded')
+      await expect(instance.warningAlreadyDownloadedText).toHaveText('v23.09.1/krux-v23.09.1.zip.sig already downloaded')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.warningAlreadyDownloadedText).toHaveText('v23.09.0\\krux-v23.09.0.zip.sig already downloaded')
+      await expect(instance.warningAlreadyDownloadedText).toHaveText('v23.09.1\\krux-v23.09.1.zip.sig already downloaded')
     }
   })
 
   it('should \'Proceed with current file\' button be displayed', async () => {
     await instance.warningDownloadProceedButton.waitForExist()
     await instance.warningDownloadProceedButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadProceedButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadProceedButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadProceedButtonText).toHaveText('Proceed with current file')
+    await expect(instance.warningDownloadProceedButton).toBeDisplayed()
+    await expect(instance.warningDownloadProceedButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadProceedButtonText).toHaveText('Proceed with current file')
   })
 
   it('should \'Download it again\' button be displayed', async () => {
     await instance.warningDownloadAgainButton.waitForExist()
     await instance.warningDownloadAgainButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadAgainButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadAgainButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadAgainButtonText).toHaveText('Download it again')
+    await expect(instance.warningDownloadAgainButton).toBeDisplayed()
+    await expect(instance.warningDownloadAgainButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadAgainButtonText).toHaveText('Download it again')
   })
 
   it('should \'Show details\' button be displayed', async () => {
     await instance.warningDownloadShowDetailsButton.waitForExist()
     await instance.warningDownloadShowDetailsButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadShowDetailsButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadShowDetailsButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadShowDetailsButtonText).toHaveText('Show details')
+    await expect(instance.warningDownloadShowDetailsButton).toBeDisplayed()
+    await expect(instance.warningDownloadShowDetailsButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadShowDetailsButtonText).toHaveText('Show details')
   })
 
   it('should \'Back\' button be displayed', async () => {
     await instance.warningDownloadBackButton.waitForExist()
     await instance.warningDownloadBackButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadBackButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadBackButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadBackButtonText).toHaveText('Back')
+    await expect(instance.warningDownloadBackButton).toBeDisplayed()
+    await expect(instance.warningDownloadBackButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadBackButtonText).toHaveText('Back')
   })
   
 })
diff --git a/test/e2e/specs/028.already-downloaded-selfcustody-release-zip-sig-click-back-button.spec.ts b/test/e2e/specs/028.already-downloaded-selfcustody-release-zip-sig-click-back-button.spec.mts
similarity index 85%
rename from test/e2e/specs/028.already-downloaded-selfcustody-release-zip-sig-click-back-button.spec.ts
rename to test/e2e/specs/028.already-downloaded-selfcustody-release-zip-sig-click-back-button.spec.mts
index 534f024d..e5879859 100644
--- a/test/e2e/specs/028.already-downloaded-selfcustody-release-zip-sig-click-back-button.spec.ts
+++ b/test/e2e/specs/028.already-downloaded-selfcustody-release-zip-sig-click-back-button.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded  release signature - click back button)', () => {
 
@@ -72,18 +69,18 @@ describe('KruxInstaller SelectVersion page (already downloaded  release signatur
   it ('should click \'Back\' button and go out from WarningDownload page', async () => {
     await instance.warningDownloadBackButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
 
   it('should Main Page be displayed', async () => {
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   }) 
 
-  it('should \'Select version\' button changed to \'Version: selfcustody/krux/releases/tag/v23.09.0\'', async () => {
+  it('should \'Select version\' button changed to \'Version: selfcustody/krux/releases/tag/v23.09.1\'', async () => {
     await instance.mainSelectVersionText.waitForExist()
-    await expectWDIO(instance.mainSelectVersionText).toBeDisplayed()
-    await expectWDIO(instance.mainSelectVersionText).toHaveText('Version: selfcustody/krux/releases/tag/v23.09.0')
+    await expect(instance.mainSelectVersionText).toBeDisplayed()
+    await expect(instance.mainSelectVersionText).toHaveText('Version: selfcustody/krux/releases/tag/v23.09.1')
   })
   
 })
diff --git a/test/e2e/specs/029.already-downloaded-selfcustody-release-zip-sig-show-details-button.spec.ts b/test/e2e/specs/029.already-downloaded-selfcustody-release-zip-sig-show-details-button.spec.mts
similarity index 72%
rename from test/e2e/specs/029.already-downloaded-selfcustody-release-zip-sig-show-details-button.spec.ts
rename to test/e2e/specs/029.already-downloaded-selfcustody-release-zip-sig-show-details-button.spec.mts
index 5d04301d..b91a4b25 100644
--- a/test/e2e/specs/029.already-downloaded-selfcustody-release-zip-sig-show-details-button.spec.ts
+++ b/test/e2e/specs/029.already-downloaded-selfcustody-release-zip-sig-show-details-button.spec.mts
@@ -1,11 +1,11 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { join } from 'path'
+import { homedir } from 'os'
+import { osLangSync } from 'os-lang'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded release signature - click show details button)', () => {
 
@@ -70,36 +70,36 @@ describe('KruxInstaller SelectVersion page (already downloaded release signature
   })
 
   it ('should overlay not be shown', async () => {
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
   })
 
   it ('should click \'Show details\' button and overlay must be visible', async () => {
     await instance.warningDownloadShowDetailsButton.click()
     await instance.warningAlreadyDownloadedOverlay.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).toBeDisplayed()
   })
 
   it('should overlay title be \'Resource details\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTitle.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTitle).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTitle).toHaveText('Resource details')
+    await expect(instance.warningAlreadyDownloadedOverlayTitle).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTitle).toHaveText('Resource details')
   })
 
-  it ('should overlay subtitle be \'v23.09.0/krux-v23.09.0.zip.sig\'', async () => {
+  it ('should overlay subtitle be \'v23.09.1/krux-v23.09.1.zip.sig\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTitle.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlaySubtitle).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlaySubtitle).toHaveText('v23.09.0/krux-v23.09.0.zip.sig')
+    await expect(instance.warningAlreadyDownloadedOverlaySubtitle).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlaySubtitle).toHaveText('v23.09.1/krux-v23.09.1.zip.sig')
   })
 
-  it ('should a overlay text have \'Remote: https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sig\'', async () => {
+  it ('should a overlay text have \'Remote: https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sig\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTextRemote.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextRemote).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextRemote).toHaveText('Remote:\nhttps://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sig')
+    await expect(instance.warningAlreadyDownloadedOverlayTextRemote).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextRemote).toHaveText('Remote:\nhttps://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sig')
   })
 
   it ('should a overlay text have properly local resource', async () => {
     await instance.warningAlreadyDownloadedOverlayTextLocal.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextLocal).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextLocal).toBeDisplayed()
     
     let resources = ''
     if (process.env.CI && process.env.GITHUB_ACTION) {
@@ -122,26 +122,26 @@ describe('KruxInstaller SelectVersion page (already downloaded release signature
       }
     }
 
-    const resource = join(resources, 'v23.09.0', 'krux-v23.09.0.zip.sig')
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextLocal).toHaveText(`Local:\n${resource}`)
+    const resource = join(resources, 'v23.09.1', 'krux-v23.09.1.zip.sig')
+    await expect(instance.warningAlreadyDownloadedOverlayTextLocal).toHaveText(`Local:\n${resource}`)
   })
 
   it('should a overlay text have the properly description', async () => {
     await instance.warningAlreadyDownloadedOverlayTextWhatdo.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextWhatdo).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextWhatdo).toHaveText('Description:\nThis file, with the public key certificate, proves the authenticity of zip file, checking if the zip file was signed by its creator.')
+    await expect(instance.warningAlreadyDownloadedOverlayTextWhatdo).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextWhatdo).toHaveText('Description:\nThis file, with the public key certificate, proves the authenticity of zip file, checking if the zip file was signed by its creator.')
   })
 
   it('should \'close\' have \'Close\' text',async () => {
     await instance.warningAlreadyDownloadedOverlayButtonClose.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayButtonClose).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayButtonClose).toHaveText('Close')
+    await expect(instance.warningAlreadyDownloadedOverlayButtonClose).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayButtonClose).toHaveText('Close')
   })
 
   it('should \'close\' button make overlay not visible', async () => {
     await instance.warningAlreadyDownloadedOverlayButtonClose.click()
     await instance.warningAlreadyDownloadedOverlay.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
   })
   
 })
diff --git a/test/e2e/specs/030.already-downloaded-selfcustody-release-zip-sig-download-again-button.spec.ts b/test/e2e/specs/030.already-downloaded-selfcustody-release-zip-sig-download-again-button.spec.mts
similarity index 81%
rename from test/e2e/specs/030.already-downloaded-selfcustody-release-zip-sig-download-again-button.spec.ts
rename to test/e2e/specs/030.already-downloaded-selfcustody-release-zip-sig-download-again-button.spec.mts
index 3cec6b52..edd74988 100644
--- a/test/e2e/specs/030.already-downloaded-selfcustody-release-zip-sig-download-again-button.spec.ts
+++ b/test/e2e/specs/030.already-downloaded-selfcustody-release-zip-sig-download-again-button.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded  release signature - click download again button)', () => {
 
@@ -73,29 +70,29 @@ describe('KruxInstaller SelectVersion page (already downloaded  release signatur
   it ('should click \'Download again\' go out of WarningDownload page', async () => {
     await instance.warningDownloadAgainButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
 
   it ('should be in DownloadOfficialReleaseSig page', async () => {
     await instance.downloadOfficialReleaseZipSigPage.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigPage).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSigPage).toBeDisplayed()
   })
 
   it('should DownloadOfficialReleaseSig page have \'Downloading\' title', async () => {
     await instance.downloadOfficialReleaseZipSigTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigTitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigTitle).toHaveText('Downloading')
+    await expect(instance.downloadOfficialReleaseZipSigTitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSigTitle).toHaveText('Downloading')
   })
 
-  it('should DownloadOfficialReleaseSig page have \'https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sig\' subtitle', async () => {
+  it('should DownloadOfficialReleaseSig page have \'https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sig\' subtitle', async () => {
     await instance.downloadOfficialReleaseZipSigSubtitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigSubtitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.0/krux-v23.09.0.zip.sig')
+    await expect(instance.downloadOfficialReleaseZipSigSubtitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSigSubtitle).toHaveText('https://github.com/selfcustody/krux/releases/download/v23.09.1/krux-v23.09.1.zip.sig')
   })
 
   it('should DownloadOfficialReleaseSig page progress until 100%', async () => {
     await instance.downloadOfficialReleaseZipSigProgress.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleaseZipSigProgress).toBeDisplayed()
+    await expect(instance.downloadOfficialReleaseZipSigProgress).toBeDisplayed()
     await instance.downloadOfficialReleaseZipSigProgress.waitUntil(async function () {
       const percentText = await this.getText()
       const percent = parseFloat(percentText.split('%')[0])
diff --git a/test/e2e/specs/031.already-downloaded-selfcustody-release-zip-sig-click-proceed-button.spec.ts b/test/e2e/specs/031.already-downloaded-selfcustody-release-zip-sig-click-proceed-button.spec.mts
similarity index 90%
rename from test/e2e/specs/031.already-downloaded-selfcustody-release-zip-sig-click-proceed-button.spec.ts
rename to test/e2e/specs/031.already-downloaded-selfcustody-release-zip-sig-click-proceed-button.spec.mts
index dc63ee4a..365dbca4 100644
--- a/test/e2e/specs/031.already-downloaded-selfcustody-release-zip-sig-click-proceed-button.spec.ts
+++ b/test/e2e/specs/031.already-downloaded-selfcustody-release-zip-sig-click-proceed-button.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded  release signature - click proceed button)', () => {
 
@@ -73,7 +70,7 @@ describe('KruxInstaller SelectVersion page (already downloaded  release signatur
   it ('should click \'Proceed\' go out of WarningDownload page', async () => {
     await instance.warningDownloadProceedButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
      
 })
diff --git a/test/e2e/specs/032-select-version-selfcustody-pem.spec.ts b/test/e2e/specs/032-select-version-selfcustody-pem.spec.mts
similarity index 82%
rename from test/e2e/specs/032-select-version-selfcustody-pem.spec.ts
rename to test/e2e/specs/032-select-version-selfcustody-pem.spec.mts
index 01cb448b..9883891a 100644
--- a/test/e2e/specs/032-select-version-selfcustody-pem.spec.ts
+++ b/test/e2e/specs/032-select-version-selfcustody-pem.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (download public key certificate)', () => {
 
@@ -73,34 +70,34 @@ describe('KruxInstaller SelectVersion page (download public key certificate)', (
    
   it ('should \'checking selfcustody.pem\' message appears', async () => {
     await instance.checkingReleasePemMsg.waitForExist()
-    await expectWDIO(instance.checkingReleasePemMsg).toBeDisplayed()
+    await expect(instance.checkingReleasePemMsg).toBeDisplayed()
   })
 
   it ('should \'main/selfcustody.pem not found\' message appears', async () => {
     await instance.notFoundReleasePemMsg.waitForExist()
-    await expectWDIO(instance.notFoundReleasePemMsg).toBeDisplayed()
+    await expect(instance.notFoundReleasePemMsg).toBeDisplayed()
   })
 
   it('should go to DownloadOfficialReleasePem page', async () => {
     await instance.downloadOfficialReleasePemPage.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleasePemPage).toBeDisplayed()
+    await expect(instance.downloadOfficialReleasePemPage).toBeDisplayed()
   })
 
   it('should DownloadOfficialReleasePem page have \'Downloading\' title', async () => {
     await instance.downloadOfficialReleasePemTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleasePemTitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleasePemTitle).toHaveText('Downloading')
+    await expect(instance.downloadOfficialReleasePemTitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleasePemTitle).toHaveText('Downloading')
   })
 
   it('should DownloadOfficialReleasePem page have \'https://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem\' subtitle', async () => {
     await instance.downloadOfficialReleasePemSubtitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleasePemSubtitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleasePemSubtitle).toHaveText('https://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem')
+    await expect(instance.downloadOfficialReleasePemSubtitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleasePemSubtitle).toHaveText('https://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem')
   })
 
   it('should DownloadOfficialReleasePem page progress until 100%', async () => {
     await instance.downloadOfficialReleasePemProgress.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleasePemProgress).toBeDisplayed()
+    await expect(instance.downloadOfficialReleasePemProgress).toBeDisplayed()
     // TODO: Pem is so small that wdio cannot check progress 
     /*await instance.downloadOfficialReleasePemProgress.waitUntil(async function () {
       const percentText = await this.getText()
diff --git a/test/e2e/specs/033.already-downloaded-selfcustody-pem.spec.ts b/test/e2e/specs/033.already-downloaded-selfcustody-pem.spec.mts
similarity index 72%
rename from test/e2e/specs/033.already-downloaded-selfcustody-pem.spec.ts
rename to test/e2e/specs/033.already-downloaded-selfcustody-pem.spec.mts
index 0f6536d9..6bfe8f35 100644
--- a/test/e2e/specs/033.already-downloaded-selfcustody-pem.spec.ts
+++ b/test/e2e/specs/033.already-downloaded-selfcustody-pem.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded public key certificate - show only)', () => {
 
@@ -73,58 +70,58 @@ describe('KruxInstaller SelectVersion page (already downloaded public key certif
    
   it ('should \'main/selfcustody.pem found\' message appears', async () => {
     await instance.checkingReleasePemMsg.waitForExist()
-    await expectWDIO(instance.checkingReleasePemMsg).toBeDisplayed()
+    await expect(instance.checkingReleasePemMsg).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.foundReleasePemMsg).toHaveText('main/selfcustody.pem found')
+      await expect(instance.foundReleasePemMsg).toHaveText('main/selfcustody.pem found')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.foundReleasePemMsg).toHaveText('main\\selfcustody.pem found')
+      await expect(instance.foundReleasePemMsg).toHaveText('main\\selfcustody.pem found')
     }
   })
   
   it('should WarningDownload page should be displayed', async () => {
     await instance.warningDownloadPage.waitForExist()
-    await expectWDIO(instance.warningDownloadPage).toBeDisplayed()
+    await expect(instance.warningDownloadPage).toBeDisplayed()
   }) 
 
   it('should \'main/selfcustody.pem already downloaded\' message be displayed', async () => {
     await instance.warningAlreadyDownloadedText.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedText).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedText).toBeDisplayed()
     if (process.platform === 'linux' || process.platform === 'darwin') {
-      await expectWDIO(instance.warningAlreadyDownloadedText).toHaveText('main/selfcustody.pem already downloaded')
+      await expect(instance.warningAlreadyDownloadedText).toHaveText('main/selfcustody.pem already downloaded')
     } else if (process.platform === 'win32') {
-      await expectWDIO(instance.warningAlreadyDownloadedText).toHaveText('main\\selfcustody.pem already downloaded')
+      await expect(instance.warningAlreadyDownloadedText).toHaveText('main\\selfcustody.pem already downloaded')
     }
   })
 
   it('should \'Proceed with current file\' button be displayed', async () => {
     await instance.warningDownloadProceedButton.waitForExist()
     await instance.warningDownloadProceedButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadProceedButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadProceedButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadProceedButtonText).toHaveText('Proceed with current file')
+    await expect(instance.warningDownloadProceedButton).toBeDisplayed()
+    await expect(instance.warningDownloadProceedButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadProceedButtonText).toHaveText('Proceed with current file')
   })
   
   it('should \'Download it again\' button be displayed', async () => {
     await instance.warningDownloadAgainButton.waitForExist()
     await instance.warningDownloadAgainButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadAgainButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadAgainButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadAgainButtonText).toHaveText('Download it again')
+    await expect(instance.warningDownloadAgainButton).toBeDisplayed()
+    await expect(instance.warningDownloadAgainButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadAgainButtonText).toHaveText('Download it again')
   })
   
   it('should \'Show details\' button be displayed', async () => {
     await instance.warningDownloadShowDetailsButton.waitForExist()
     await instance.warningDownloadShowDetailsButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadShowDetailsButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadShowDetailsButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadShowDetailsButtonText).toHaveText('Show details')
+    await expect(instance.warningDownloadShowDetailsButton).toBeDisplayed()
+    await expect(instance.warningDownloadShowDetailsButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadShowDetailsButtonText).toHaveText('Show details')
   })
   
   it('should \'Back\' button be displayed', async () => {
     await instance.warningDownloadBackButton.waitForExist()
     await instance.warningDownloadBackButtonText.waitForExist()
-    await expectWDIO(instance.warningDownloadBackButton).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadBackButtonText).toBeDisplayed()
-    await expectWDIO(instance.warningDownloadBackButtonText).toHaveText('Back')
+    await expect(instance.warningDownloadBackButton).toBeDisplayed()
+    await expect(instance.warningDownloadBackButtonText).toBeDisplayed()
+    await expect(instance.warningDownloadBackButtonText).toHaveText('Back')
   })
 })
diff --git a/test/e2e/specs/034.already-downloaded-selfcustody-pem-click-back-button.spec.ts b/test/e2e/specs/034.already-downloaded-selfcustody-pem-click-back-button.spec.mts
similarity index 86%
rename from test/e2e/specs/034.already-downloaded-selfcustody-pem-click-back-button.spec.ts
rename to test/e2e/specs/034.already-downloaded-selfcustody-pem-click-back-button.spec.mts
index 6ef1d451..22464f82 100644
--- a/test/e2e/specs/034.already-downloaded-selfcustody-pem-click-back-button.spec.ts
+++ b/test/e2e/specs/034.already-downloaded-selfcustody-pem-click-back-button.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded public key certificate - click back button)', () => {
 
@@ -78,17 +75,17 @@ describe('KruxInstaller SelectVersion page (already downloaded public key certif
   it ('should click \'Back\' button and go out from WarningDownload page', async () => {
     await instance.warningDownloadBackButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
     
   it('should Main Page be displayed', async () => {
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
    
-  it('should \'Select version\' button changed to \'Version: selfcustody/krux/releases/tag/v23.09.0\'', async () => {
+  it('should \'Select version\' button changed to \'Version: selfcustody/krux/releases/tag/v23.09.1\'', async () => {
     await instance.mainSelectVersionText.waitForExist()
-    await expectWDIO(instance.mainSelectVersionText).toBeDisplayed()
-    await expectWDIO(instance.mainSelectVersionText).toHaveText('Version: selfcustody/krux/releases/tag/v23.09.0')
+    await expect(instance.mainSelectVersionText).toBeDisplayed()
+    await expect(instance.mainSelectVersionText).toHaveText('Version: selfcustody/krux/releases/tag/v23.09.1')
   })
 })
diff --git a/test/e2e/specs/035.already-downloaded-selfcustody-pem-show-details-button.spec.ts b/test/e2e/specs/035.already-downloaded-selfcustody-pem-show-details-button.spec.mts
similarity index 76%
rename from test/e2e/specs/035.already-downloaded-selfcustody-pem-show-details-button.spec.ts
rename to test/e2e/specs/035.already-downloaded-selfcustody-pem-show-details-button.spec.mts
index a03c5271..d2ffbefc 100644
--- a/test/e2e/specs/035.already-downloaded-selfcustody-pem-show-details-button.spec.ts
+++ b/test/e2e/specs/035.already-downloaded-selfcustody-pem-show-details-button.spec.mts
@@ -1,11 +1,11 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { join } from 'path'
+import { homedir } from 'os'
+import { osLangSync } from 'os-lang'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded public key certificate - click show details button)', () => {
 
@@ -76,36 +76,36 @@ describe('KruxInstaller SelectVersion page (already downloaded public key certif
   })
 
   it ('should overlay not be shown', async () => {
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
   })
 
   it ('should click \'Show details\' button and overlay must be visible', async () => {
     await instance.warningDownloadShowDetailsButton.click()
     await instance.warningAlreadyDownloadedOverlay.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).toBeDisplayed()
   })
 
   it('should overlay title be \'Resource details\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTitle.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTitle).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTitle).toHaveText('Resource details')
+    await expect(instance.warningAlreadyDownloadedOverlayTitle).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTitle).toHaveText('Resource details')
   })
 
   it ('should overlay subtitle be \'main/selfcustody.pem\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTitle.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlaySubtitle).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlaySubtitle).toHaveText('main/selfcustody.pem')
+    await expect(instance.warningAlreadyDownloadedOverlaySubtitle).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlaySubtitle).toHaveText('main/selfcustody.pem')
   })
 
   it ('should a overlay text have \'Remote: https://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem\'', async () => {
     await instance.warningAlreadyDownloadedOverlayTextRemote.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextRemote).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextRemote).toHaveText('Remote:\nhttps://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem')
+    await expect(instance.warningAlreadyDownloadedOverlayTextRemote).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextRemote).toHaveText('Remote:\nhttps://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem')
   })
 
   it ('should a overlay text have properly local resource', async () => {
     await instance.warningAlreadyDownloadedOverlayTextLocal.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextLocal).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextLocal).toBeDisplayed()
     
     let resources = ''
     if (process.env.CI && process.env.GITHUB_ACTION) {
@@ -129,24 +129,24 @@ describe('KruxInstaller SelectVersion page (already downloaded public key certif
     }
 
     const resource = join(resources, 'main', 'selfcustody.pem')
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextLocal).toHaveText(`Local:\n${resource}`)
+    await expect(instance.warningAlreadyDownloadedOverlayTextLocal).toHaveText(`Local:\n${resource}`)
   })
 
   it('should a overlay text have the properly description', async () => {
     await instance.warningAlreadyDownloadedOverlayTextWhatdo.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextWhatdo).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayTextWhatdo).toHaveText('Description:\nThis file, with the signature, proves the authenticity of zip file, checking if the zip file was signed by its creator.')
+    await expect(instance.warningAlreadyDownloadedOverlayTextWhatdo).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayTextWhatdo).toHaveText('Description:\nThis file, with the signature, proves the authenticity of zip file, checking if the zip file was signed by its creator.')
   })
   
   it('should \'close\' have \'Close\' text',async () => {
     await instance.warningAlreadyDownloadedOverlayButtonClose.waitForExist()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayButtonClose).toBeDisplayed()
-    await expectWDIO(instance.warningAlreadyDownloadedOverlayButtonClose).toHaveText('Close')
+    await expect(instance.warningAlreadyDownloadedOverlayButtonClose).toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlayButtonClose).toHaveText('Close')
   })
 
   it('should \'close\' button make overlay not visible', async () => {
     await instance.warningAlreadyDownloadedOverlayButtonClose.click()
     await instance.warningAlreadyDownloadedOverlay.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
+    await expect(instance.warningAlreadyDownloadedOverlay).not.toBeDisplayed()
   })
 })
\ No newline at end of file
diff --git a/test/e2e/specs/036.already-downloaded-selfcustody-pem-download-again-button.spec.ts b/test/e2e/specs/036.already-downloaded-selfcustody-pem-download-again-button.spec.mts
similarity index 84%
rename from test/e2e/specs/036.already-downloaded-selfcustody-pem-download-again-button.spec.ts
rename to test/e2e/specs/036.already-downloaded-selfcustody-pem-download-again-button.spec.mts
index 12e001a1..ea7a203b 100644
--- a/test/e2e/specs/036.already-downloaded-selfcustody-pem-download-again-button.spec.ts
+++ b/test/e2e/specs/036.already-downloaded-selfcustody-pem-download-again-button.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded public key certificate - click download again button)', () => {
 
@@ -78,29 +75,29 @@ describe('KruxInstaller SelectVersion page (already downloaded public key certif
   it ('should click \'Download again\' go out of WarningDownload page', async () => {
     await instance.warningDownloadAgainButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
 
   it ('should be in DownloadOfficialReleasePem page', async () => {
     await instance.downloadOfficialReleasePemPage.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleasePemPage).toBeDisplayed()
+    await expect(instance.downloadOfficialReleasePemPage).toBeDisplayed()
   })
 
   it('should DownloadOfficialReleasePem page have \'Downloading\' title', async () => {
     await instance.downloadOfficialReleasePemTitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleasePemTitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleasePemTitle).toHaveText('Downloading')
+    await expect(instance.downloadOfficialReleasePemTitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleasePemTitle).toHaveText('Downloading')
   })
 
   it('should DownloadOfficialReleasePem page have \'https://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem\' subtitle', async () => {
     await instance.downloadOfficialReleasePemSubtitle.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleasePemSubtitle).toBeDisplayed()
-    await expectWDIO(instance.downloadOfficialReleasePemSubtitle).toHaveText('https://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem')
+    await expect(instance.downloadOfficialReleasePemSubtitle).toBeDisplayed()
+    await expect(instance.downloadOfficialReleasePemSubtitle).toHaveText('https://raw.githubusercontent.com/selfcustody/krux/main/selfcustody.pem')
   })
 
   it('should DownloadOfficialReleasePem page progress until 100%', async () => {
     await instance.downloadOfficialReleasePemProgress.waitForExist()
-    await expectWDIO(instance.downloadOfficialReleasePemProgress).toBeDisplayed()
+    await expect(instance.downloadOfficialReleasePemProgress).toBeDisplayed()
     // TODO: Pem is so small that wdio cannot check progress 
     /*await instance.downloadOfficialReleasePemProgress.waitUntil(async function () {
       const percentText = await this.getText()
diff --git a/test/e2e/specs/037.already-downloaded-selfcustody-pem-click-proceed-button.spec.ts b/test/e2e/specs/037.already-downloaded-selfcustody-pem-click-proceed-button.spec.mts
similarity index 91%
rename from test/e2e/specs/037.already-downloaded-selfcustody-pem-click-proceed-button.spec.ts
rename to test/e2e/specs/037.already-downloaded-selfcustody-pem-click-proceed-button.spec.mts
index fa4690eb..344be9da 100644
--- a/test/e2e/specs/037.already-downloaded-selfcustody-pem-click-proceed-button.spec.ts
+++ b/test/e2e/specs/037.already-downloaded-selfcustody-pem-click-proceed-button.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 describe('KruxInstaller SelectVersion page (already downloaded public key certificate - click proceed again button)', () => {
 
@@ -80,7 +77,7 @@ describe('KruxInstaller SelectVersion page (already downloaded public key certif
   it ('should click \'Proceed\' go out of WarningDownload page', async () => {
     await instance.warningDownloadProceedButton.click()
     await instance.warningDownloadPage.waitForExist({ reverse: true })
-    await expectWDIO(instance.warningDownloadPage).not.toBeDisplayed()
+    await expect(instance.warningDownloadPage).not.toBeDisplayed()
   })
 
 })
\ No newline at end of file
diff --git a/test/e2e/specs/038-check-verify-official-release.spec.ts b/test/e2e/specs/038-check-verify-official-release.spec.mts
similarity index 92%
rename from test/e2e/specs/038-check-verify-official-release.spec.ts
rename to test/e2e/specs/038-check-verify-official-release.spec.mts
index f9495bbb..78a0fc06 100644
--- a/test/e2e/specs/038-check-verify-official-release.spec.ts
+++ b/test/e2e/specs/038-check-verify-official-release.spec.mts
@@ -1,11 +1,8 @@
-const expectChai = require('chai').expect
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
 
 const LEN_SASSAMAN = [
     ":.:'' ,,xiW,\"4x, ''           ",
@@ -108,12 +105,12 @@ describe('KruxInstaller CheckVerifyOfficialRelease page (show Lensassaman \'usin
 
   it('should go to CheckVerifyOfficialRelease page', async () => { 
     await instance.checkVerifyOfficialReleasePage.waitForExist({ timeout: 3000 })
-    await expectWDIO(instance.checkVerifyOfficialReleasePage).toBeDisplayed()
+    await expect(instance.checkVerifyOfficialReleasePage).toBeDisplayed()
   })
 
   it('should show correctly Len Sassaman \'verifying\' with openssl', async () => {
     await instance.checkVerifyOfficialReleaseLenSassamanIsUsingOpenssl.waitForExist()
-    await expectWDIO(instance.checkVerifyOfficialReleaseLenSassamanIsUsingOpenssl).toHaveText(LEN_SASSAMAN)
+    await expect(instance.checkVerifyOfficialReleaseLenSassamanIsUsingOpenssl).toHaveText(LEN_SASSAMAN)
   })
 
   it('should go out of CheckVerifyOfficialRelease page', async () => {
diff --git a/test/e2e/specs/039-verified-official-release.spec.ts b/test/e2e/specs/039-verified-official-release.spec.mts
similarity index 75%
rename from test/e2e/specs/039-verified-official-release.spec.ts
rename to test/e2e/specs/039-verified-official-release.spec.mts
index f0344fba..4daf8633 100644
--- a/test/e2e/specs/039-verified-official-release.spec.ts
+++ b/test/e2e/specs/039-verified-official-release.spec.mts
@@ -1,10 +1,13 @@
-const expectWDIO = require('@wdio/globals').expect
-const { join } = require('path')
-const { homedir } = require('os')
-const { osLangSync } = require('os-lang')
-const { describe, it } = require('mocha')
+import { expect } from '@wdio/globals'
+import { describe, it } from 'mocha'
+import { join } from 'path'
+import { homedir } from 'os'
+import { osLangSync } from 'os-lang'
+import { createRequire } from 'module'
 
-const App = require('../pageobjects/app.page')
+const App = createRequire(import.meta.url)('../pageobjects/app.page')
+
+const SHA256 = "4d 58 39 27 a7 22 06 e0 2a 8e 58 13 48 94 37 7c 94 e2 cc 9b 65 1f 16 11 bd de 1f bf 29 4c 78 26"
 
 describe('KruxInstaller VerifiedOfficialRelease page (show and click back button)', () => {
 
@@ -84,36 +87,37 @@ describe('KruxInstaller VerifiedOfficialRelease page (show and click back button
 
   it('should show VerifiedOfficialRelease page', async () => {
     await instance.verifiedOfficialReleasePage.waitForExist()
-    await expectWDIO(instance.verifiedOfficialReleasePage).toBeDisplayed()
+    await expect(instance.verifiedOfficialReleasePage).toBeDisplayed()
   })
 
   it('should show sha256sum intergrity title', async () => {
     await instance.verifiedOfficialReleasePageSha2256IntegrityTitle.waitForExist()
-    await expectWDIO(instance.verifiedOfficialReleasePageSha2256IntegrityTitle).toBeDisplayed()     
-    await expectWDIO(instance.verifiedOfficialReleasePageSha2256IntegrityTitle).toHaveText('Sha256sum integrity')
+    await expect(instance.verifiedOfficialReleasePageSha2256IntegrityTitle).toBeDisplayed()     
+    await expect(instance.verifiedOfficialReleasePageSha2256IntegrityTitle).toHaveText('Sha256sum integrity')
   })
 
   it('should show sha256sum intergrity sha256.txt', async () => {
     await instance.verifiedOfficialReleasePageSha2256IntegritySha256txt.waitForExist()
-    await expectWDIO(instance.verifiedOfficialReleasePageSha2256IntegritySha256txt).toBeDisplayed()
-    await expectWDIO(instance.verifiedOfficialReleasePageSha2256IntegritySha256txt).toHaveText('Expected result from file v23.09.0/krux-v23.09.0.zip.sha256.txt\n4a 8a a4 0b 71 f7 df 35 5b d1 54 ff ac 9c 9f 10 99 e8 7a 89 c0 53 32 58 7e bc 02 a2 15 92 ec 1b')
+    await expect(instance.verifiedOfficialReleasePageSha2256IntegritySha256txt).toBeDisplayed()
+    
+    await expect(instance.verifiedOfficialReleasePageSha2256IntegritySha256txt).toHaveText(`Expected result from file v23.09.1/krux-v23.09.1.zip.sha256.txt\n${SHA256}`)
   })
 
   it('should show sha256sum intergrity sha256 summed result', async () => {
     await instance.verifiedOfficialReleasePageSha2256IntegritySha256.waitForExist()
-    await expectWDIO(instance.verifiedOfficialReleasePageSha2256IntegritySha256).toBeDisplayed()
-    await expectWDIO(instance.verifiedOfficialReleasePageSha2256IntegritySha256).toHaveText('Summed result of file v23.09.0/krux-v23.09.0.zip\n4a 8a a4 0b 71 f7 df 35 5b d1 54 ff ac 9c 9f 10 99 e8 7a 89 c0 53 32 58 7e bc 02 a2 15 92 ec 1b')
+    await expect(instance.verifiedOfficialReleasePageSha2256IntegritySha256).toBeDisplayed()
+    await expect(instance.verifiedOfficialReleasePageSha2256IntegritySha256).toHaveText(`Summed result of file v23.09.1/krux-v23.09.1.zip\n${SHA256}`)
   })
   
   it('should show openssl authenticity title', async () => {
     await instance.verifiedOfficialReleasePageSignatureTitle.waitForExist()
-    await expectWDIO(instance.verifiedOfficialReleasePageSignatureTitle).toBeDisplayed()     
-    await expectWDIO(instance.verifiedOfficialReleasePageSignatureTitle).toHaveText('Signature authenticity')
+    await expect(instance.verifiedOfficialReleasePageSignatureTitle).toBeDisplayed()     
+    await expect(instance.verifiedOfficialReleasePageSignatureTitle).toHaveText('Signature authenticity')
   })
 
   it('should show openssl authenticity command', async () => {
     await instance.verifiedOfficialReleasePageSignatureCommand.waitForExist()
-    await expectWDIO(instance.verifiedOfficialReleasePageSignatureCommand).toBeDisplayed()
+    await expect(instance.verifiedOfficialReleasePageSignatureCommand).toBeDisplayed()
     
     let resources = ''
     let openssl = ''
@@ -145,9 +149,9 @@ describe('KruxInstaller VerifiedOfficialRelease page (show and click back button
       }
     }
 
-    const resourceZip = join(resources, 'v23.09.0', 'krux-v23.09.0.zip')
+    const resourceZip = join(resources, 'v23.09.1', 'krux-v23.09.1.zip')
     const resourcePem = join(resources, 'main', 'selfcustody.pem')
-    const resourceSig = join(resources, 'v23.09.0', 'krux-v23.09.0.zip.sig')
+    const resourceSig = join(resources, 'v23.09.1', 'krux-v23.09.1.zip.sig')
     const command = [
       '$>',
       `${openssl} sha256 <${resourceZip}`,
@@ -163,19 +167,19 @@ describe('KruxInstaller VerifiedOfficialRelease page (show and click back button
       resourceSig
     ].join(' ')
 
-    await expectWDIO(instance.verifiedOfficialReleasePageSignatureCommand).toHaveText(command)
+    await expect(instance.verifiedOfficialReleasePageSignatureCommand).toHaveText(command)
   })
 
   it('should show openssl authenticity command result', async () => {
     await instance.verifiedOfficialReleasePageSignatureResult.waitForExist()
-    await expectWDIO(instance.verifiedOfficialReleasePageSignatureResult).toBeDisplayed()     
-    await expectWDIO(instance.verifiedOfficialReleasePageSignatureResult).toHaveText('Signature Verified Successfully')
+    await expect(instance.verifiedOfficialReleasePageSignatureResult).toBeDisplayed()     
+    await expect(instance.verifiedOfficialReleasePageSignatureResult).toHaveText('Signature Verified Successfully')
   })
 
   it('should show back button', async () => {
     await instance.verifiedOfficialReleasePageBackButton.waitForExist()
-    await expectWDIO(instance.verifiedOfficialReleasePageBackButton).toBeDisplayed()     
-    await expectWDIO(instance.verifiedOfficialReleasePageBackButton).toHaveText('Back')
+    await expect(instance.verifiedOfficialReleasePageBackButton).toBeDisplayed()     
+    await expect(instance.verifiedOfficialReleasePageBackButton).toHaveText('Back')
   })
 
   it('should click back button, exit from VerifiedOfficialRelease page', async () => {
@@ -184,9 +188,8 @@ describe('KruxInstaller VerifiedOfficialRelease page (show and click back button
   })
 
   it('should be in Main page', async () => {
-    await instance.verifiedOfficialReleasePageBackButton.click()
     await instance.mainPage.waitForExist()
-    await expectWDIO(instance.mainPage).toBeDisplayed()
+    await expect(instance.mainPage).toBeDisplayed()
   })
 
 })
\ No newline at end of file
diff --git a/vite.config.ts b/vite.config.ts
index 8edab32e..2960fb47 100644
--- a/vite.config.ts
+++ b/vite.config.ts
@@ -72,7 +72,7 @@ export default defineConfig(({ command }) => {
         minify: true,
         inject: {
           data: {
-            title: `${pkg.name} ${pkg.version}${pkg.revision !== '' ? '.' + pkg.revision : ''}`
+            title: `${pkg.name} ${pkg.version}`
           }
         }
       })
diff --git a/wdio.conf.mts b/wdio.conf.mts
index ef5e7fde..706599c9 100644
--- a/wdio.conf.mts
+++ b/wdio.conf.mts
@@ -7,29 +7,32 @@ import { createRequire } from 'module'
 import { osLangSync } from 'os-lang'
 import createDebug from 'debug'
 import { accessSync } from 'fs';
+import { exec, execFile } from 'child_process';
 
 const { devDependencies, version } = createRequire(import.meta.url)('./package.json')
 const debug = createDebug('krux:wdio:e2e')
 const __filename = fileURLToPath(import.meta.url);
 const __dirname = dirname(__filename);
 
-// force TEST to be true
-if (!process.env.TEST || process.env.TEST !== 'true') {
-  debug('Force TEST=true')
-  process.env.TEST = 'true'
-}
-
-// force WDIO_ELECTRON to be true
-if (!process.env.WDIO_ELECTRON || process.env.WDIO_ELECTRON !== 'true') {
-  debug('Force WDIO_ELECTRON=true')
-  process.env.WDIO_ELECTRON = 'true'
+// select the correct binary
+// for each OS
+let APP_PATH: string
+if (process.platform === 'linux') {
+  APP_PATH = join(__dirname, 'release', version, 'linux-unpacked', 'krux-installer')
+} else if (process.platform === 'win32') {
+  APP_PATH = join(__dirname, 'release', version, 'win-unpacked', 'krux-installer.exe')
+} else if (process.platform === 'darwin') {
+  APP_PATH = join(__dirname, 'release', version, 'mac', 'krux-installer.app', 'Contents', 'MacOS', 'krux-installer')
+} else {
+  throw new Error(`Platform '${process.platform}' not implemented`)
 }
 
-// force VITE_COVERAGE to be true
-if (!process.env.VITE_COVERAGE || process.env.VITE_COVERAGE !== 'true') {
-  debug('Force VITE_COVERAGE=true')
-  process.env.VITE_COVERAGE = 'true'
-}
+const APP_ARGS = [
+  '--disable-infobars',
+  '--disable-dev-shm-usage',
+  '--no-sandbox',
+  '--remote-debugging-port=9222'
+]
 
 // Define which specs to
 // test or to exclude
@@ -61,7 +64,7 @@ if (process.env.CI && process.env.GITHUB_ACTION) {
 }
 
 // Define where specs are located
-const specs = globSync('./test/e2e/specs/*.spec.ts')
+const specs = globSync('./test/e2e/specs/*.spec.mts')
 
 // If you want to filter some test, you could use
 // a `--filter` with regular expression
@@ -204,19 +207,11 @@ export const config = {
         // grid with only 5 firefox instances available you can make sure that not more than
         // 5 instances get started at a time.
         maxInstances: 1,
-        browserName: 'chrome',
-        //acceptInsecureCerts: true
-        'goog:chromeOptions': {
-          args: []
+        browserName: 'electron',
+        'wdio:electronServiceOptions': {
+          appBinaryPath: APP_PATH,
+          appArgs: APP_ARGS,
         }
-        //  prefs: {
-        //    enable_do_not_track: true
-        //  }
-        //}
-        // If outputDir is provided WebdriverIO can capture driver session logs
-        // it is possible to configure which logTypes to include/exclude.
-        // excludeDriverLogs: ['*'], // pass '*' to exclude all driver session logs
-        // excludeDriverLogs: ['bugreport', 'server'],
     }],
     //
     // ===================
@@ -265,28 +260,7 @@ export const config = {
     // Services take over a specific job you don't want to take care of. They enhance
     // your test setup with almost no effort. Unlike plugins, they don't add new
     // commands. Instead, they hook themselves up into the test process.
-    services: [
-      [
-        'electron',
-        {
-          appPath: join(__dirname, 'release', version),
-          appName: 'krux-installer',
-          //binaryPath: APP_PATH,
-          appArgs: [
-            '--disable-infobars',
-            '--disable-dev-shm-usage',
-            '--no-sandbox',
-            '--remote-debugging-port=9222'
-          ],
-          chromedriver: {
-            port: 9519,
-            logFileName: 'wdio-chromedriver.log',
-            //chromedriverCustomPath: createRequire(import.meta.url).resolve(join('chromedriver', 'bin', 'chromedriver'))
-          },
-          electronVersion: devDependencies.electron.split("^")[1]
-        }
-      ]
-    ],
+    services: ['electron'],
     // Framework you want to run your specs with.
     // The following are supported: Mocha, Jasmine, and Cucumber
     // see also: https://webdriver.io/docs/frameworks
@@ -340,8 +314,71 @@ export const config = {
      * @param  {[type]} args     object that will be merged with the main configuration once worker is initialized
      * @param  {[type]} execArgv list of string arguments passed to the worker process
      */
-    //onWorkerStart: function (cid: string, caps: any, specs: any, args: any, execArgv: any) {
-    //},
+    onWorkerStart: function (cid: string, caps: any, specs: any, args: any, execArgv: any) {
+      // This is a little 'hacking'
+      // the created 'krux-installer' process generated by
+      // webdriveIO do not properly create the store
+      // so we will run an no-test 'krux-installer'
+      // that create the store, kill it
+      // and then start to test
+      return new Promise(async function(resolve, reject) {
+        if (specs[0].indexOf('000.create-config.spec.mts') !== -1) {
+          const shell = process.env.SHELL
+          debug(`platform: ${process.platform}`)
+          debug(`shell: ${shell}`)
+          debug('INTERMEDIATE RUNNING TO CREATE STORE')
+
+          // Get the Process ID to stop it after exection
+          debug(`exec: ${APP_PATH}`)
+          debug(`args: ${APP_ARGS.join(' ')}`)
+          const app = execFile(APP_PATH, APP_ARGS)
+          debug(`PID ${app.pid}`)
+          
+          // Wait for some time, show the config file path
+          // and stop the process killing it providing it pid.
+          // Linux and darwin have similar ways to do this (`kill` command);
+          // on windows, we will use powershell `Stop-Process -Id` arg
+          // or cmd with `Taskkill /F /PID`
+          if (process.platform !== 'linux' && process.platform !== 'win32' && process.platform !== 'darwin') {
+            const err = new Error(`Not implement for ${process.platform}`)
+            debug(err)
+            reject(err)
+          } else {
+            let store = ''
+            let killCmd = ''
+
+            if (process.platform === 'linux') {
+              store = join(process.env.HOME as string, '.config', 'krux-installer')
+              killCmd = `kill ${app.pid}`
+            }
+          
+            if (process.platform === 'win32') {
+              store = join(process.env.APPDATA as string, 'krux-installer')
+              killCmd = `Taskkill /F /PID ${app.pid}`
+              //killCmd = `Stop-Process -Id ${app.pid}`
+            } 
+          
+            if (process.platform === 'darwin') {
+              store = join(process.env.HOME as string, 'Library', 'Application Support', 'krux-installer')
+              killCmd = `kill ${app.pid}`
+            }
+
+            setTimeout(function () {
+              exec(killCmd, function(err) {
+                if (err) {
+                  debug(err)
+                  reject(err)
+                }
+                debug(`killed process ${app.pid}`)
+                resolve()
+              })
+            }, 10000)
+          }
+        } else {
+          resolve()
+        }
+      })
+    },
     /**
      * Gets executed just after a worker process has exited.
      * @param  {String} cid      capability id (e.g 0-0)