From cb4a75009a251e40247b13fce554dfd560e7ed02 Mon Sep 17 00:00:00 2001 From: Sayantam Dey Date: Tue, 30 Mar 2021 13:18:28 +0530 Subject: [PATCH] Show indicator when updating AWS price --- docker-compose.yml | 2 +- hailstorm-web-client/package-lock.json | 2 +- hailstorm-web-client/package.json | 2 +- .../AWSInstanceChoice.test.tsx | 17 +++++++++++++++-- .../ClusterConfiguration/AWSInstanceChoice.tsx | 17 ++++++++++++----- 5 files changed, 30 insertions(+), 10 deletions(-) diff --git a/docker-compose.yml b/docker-compose.yml index 1eda80d3..379f0f51 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,7 +1,7 @@ version: '3.2' services: web: - image: "hailstorm3/hailstorm-web-client:1.7.9" + image: "hailstorm3/hailstorm-web-client:1.7.10" ports: - "8080:80" networks: diff --git a/hailstorm-web-client/package-lock.json b/hailstorm-web-client/package-lock.json index 2a15b6c1..974c9160 100644 --- a/hailstorm-web-client/package-lock.json +++ b/hailstorm-web-client/package-lock.json @@ -1,6 +1,6 @@ { "name": "hailstorm-web-client", - "version": "1.7.9", + "version": "1.7.10", "lockfileVersion": 1, "requires": true, "dependencies": { diff --git a/hailstorm-web-client/package.json b/hailstorm-web-client/package.json index 70036139..b5e258d4 100644 --- a/hailstorm-web-client/package.json +++ b/hailstorm-web-client/package.json @@ -1,6 +1,6 @@ { "name": "hailstorm-web-client", - "version": "1.7.9", + "version": "1.7.10", "private": true, "dependencies": { "date-fns": "^2.6.0", diff --git a/hailstorm-web-client/src/ClusterConfiguration/AWSInstanceChoice.test.tsx b/hailstorm-web-client/src/ClusterConfiguration/AWSInstanceChoice.test.tsx index c20629f4..f4570b9f 100644 --- a/hailstorm-web-client/src/ClusterConfiguration/AWSInstanceChoice.test.tsx +++ b/hailstorm-web-client/src/ClusterConfiguration/AWSInstanceChoice.test.tsx @@ -1,10 +1,10 @@ import React from 'react'; import { render, mount } from 'enzyme'; -import { AWSInstanceChoice } from './AWSInstanceChoice'; +import { AWSInstanceChoice, InstanceTypeMeter } from './AWSInstanceChoice'; import { AWSInstanceChoiceOption } from './domain'; import { render as renderComponent, fireEvent } from '@testing-library/react'; import { Form, Formik } from 'formik'; -import { AppNotificationProviderWithProps } from '../AppNotificationProvider/AppNotificationProvider'; +import { AppNotificationProviderWithProps } from '../AppNotificationProvider'; jest.mock('./NonLinearSlider', () => ({ __esModule: true, @@ -244,4 +244,17 @@ describe('', () => { fireEvent.change(maxThreadsByInst, {target: {value: ''}}); expect(maxThreadsByInst.getAttribute('value')).toEqual(presetValue); }); + + it('show an indicator before price update', async () => { + const component = mount( + + ); + + expect(component).toContainExactlyOneMatchingElement('LoadingMessage'); + component.setProps({hourlyCostByCluster: 0.12}); + expect(component).not.toContain('LoadingMessage'); + }); }); diff --git a/hailstorm-web-client/src/ClusterConfiguration/AWSInstanceChoice.tsx b/hailstorm-web-client/src/ClusterConfiguration/AWSInstanceChoice.tsx index f019a3b5..a7d4f682 100644 --- a/hailstorm-web-client/src/ClusterConfiguration/AWSInstanceChoice.tsx +++ b/hailstorm-web-client/src/ClusterConfiguration/AWSInstanceChoice.tsx @@ -2,7 +2,7 @@ import React, { useState, useEffect } from 'react'; import { NonLinearSlider } from './NonLinearSlider'; import { computeChoice, maxThreadsByCluster } from './AWSInstanceCalculator'; import { AWSInstanceChoiceOption } from './domain'; -import { Loader } from '../Loader/Loader'; +import { Loader, LoadingMessage } from '../Loader'; import { Field } from 'formik'; import { useNotifications } from '../app-notifications'; @@ -46,6 +46,7 @@ export function AWSInstanceChoice({ console.debug('AWSInstanceChoice#useEffect(regionCode)'); if (!quickMode) return; + setHourlyCostByCluster && setHourlyCostByCluster(undefined); fetchPricing(regionCode) .then((data) => { setPricingData(data); @@ -253,7 +254,7 @@ function InstanceTypeInput({ ) } -function InstanceTypeMeter({ +export function InstanceTypeMeter({ instanceType, numInstances, hourlyCostByCluster @@ -270,9 +271,15 @@ function InstanceTypeMeter({ {numInstances} - {hourlyCostByCluster && ( - ${hourlyCostByCluster.toFixed(4)} - )} + {hourlyCostByCluster ? ( + + ${hourlyCostByCluster.toFixed(4)} + + ):( + + + + )} ); }