Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

MTV-1726: Edit VMs list in migration plan #1414

Open
wants to merge 6 commits into
base: main
Choose a base branch
from

Conversation

jschuler
Copy link
Contributor

@jschuler jschuler commented Dec 16, 2024

https://issues.redhat.com/browse/MTV-1726

Design story:
https://issues.redhat.com/browse/HPUX-166

Provide users the possibility to add more VMs (not just delete) to an existing plan.
See this table below for when it is possible to do so.
Basically, whenever you can update plan mappings, you can also update plan VMs.

For the mappings section, I reused the plan details mappings tab section, since it can patch existing mappings

Plan status VMs status Can select to cancel Can select to remove Can edit plan VMs (add/remove) Can edit mappings Notes
Running TRUE FALSE FALSE FALSE
Succeeded FALSE FALSE FALSE FALSE no actions available
Failed At least 1 VM migrated FALSE TRUE TRUE (non-migrated only) TRUE (non-migrated only) can restart plan
Canceled At least 1 VM migrated FALSE TRUE TRUE (non-migrated only) TRUE (non-migrated only) can restart plan
Failed No VM migrated FALSE FALSE TRUE TRUE
Canceled No VM migrated FALSE FALSE TRUE TRUE
Ready FALSE FALSE TRUE TRUE
Error FALSE FALSE TRUE TRUE No VMs were migrated

See video of before (green border)/after:

Screen.Recording.2024-12-13.at.12.04.40.PM.mov

@@ -0,0 +1,149 @@
import React, { useState } from 'react';
Copy link
Contributor Author

@jschuler jschuler Dec 16, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this is basically a copy of packages/forklift-console-plugin/src/components/page/StandardPageWithSelection.tsx but without selection, only expansion

This variation is needed for Edit VMs case since there should be no checkboxes, just expandable rows.

@@ -0,0 +1 @@
export type PlanEditAction = 'PLAN' | 'VMS';
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it will allow us next (with small changes like this) to edit plans too

loadError: unknown;
loaded?: boolean;
loadError?: unknown;
planMappingsState: PlanMappingsSectionState;
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I lifted the state up so that we can reuse planmappings from Edit VMs case


import '../create/PlanCreatePage.style.css';

export const PlanEditPage: React.FC<{
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

initially copied from PlanCreatePage, but there were enough changes to make it its own component

@codecov-commenter
Copy link

codecov-commenter commented Dec 16, 2024

⚠️ Please install the 'codecov app svg image' to ensure uploads and comments are reliably processed by Codecov.

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 36.20%. Comparing base (13484d0) to head (0eafaf8).
Report is 184 commits behind head on main.

❗ Your organization needs to install the Codecov GitHub app to enable full functionality.

Additional details and impacted files
@@            Coverage Diff             @@
##             main    #1414      +/-   ##
==========================================
- Coverage   36.81%   36.20%   -0.62%     
==========================================
  Files         158      159       +1     
  Lines        2548     2580      +32     
  Branches      599      616      +17     
==========================================
- Hits          938      934       -4     
- Misses       1428     1451      +23     
- Partials      182      195      +13     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

[MTV-1686] Simplify/update migration plan status cell

Signed-off-by: Joachim Schuler <[email protected]>
Signed-off-by: Joachim Schuler <[email protected]>
@yaacov
Copy link
Member

yaacov commented Dec 29, 2024

@sgratch please review

@jschuler happy holidays, @sgratch the maintainer, asked to review big PRs so we will wait for her review.

Signed-off-by: Joachim Schuler <[email protected]>
@jschuler jschuler requested a review from sgratch January 10, 2025 20:08
Copy link
Collaborator

@metalice metalice left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @jschuler

I went over the PR, following our best practices, and I didn't comment on everything as I trust that you will understand from the comments that I did add and adjust in all the places that it fit. If something isn't clear, just let me know over Slack

}, [state.flow.editingDone]);
};

async function updateMappings(
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems redundant? Only moving args?

import { setAPiError } from './reducer/actions';
import { CreateVmMigrationPageState } from './types';

const updatePlan = async (plan: V1beta1Plan) => {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

please export to a util file, and improve to a meaningful naming, ex. updatePlanSpecVMS

return;
}

Promise.all([
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can we convert to try catch with await ?

});
};

export const useUpdateEffect = (
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why are we updaing state in this hook? do we really need this hook? its not returning anything

namespace,
},
spec: {
...planTemplate?.spec,
...plan?.spec,
provider: {
source: getObjectRef(sourceProvider),
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

no need for ...plan?.spec?.provider here?

Comment on lines +191 to +202
const migratedVmIds = plan?.status?.migration?.vms?.reduce((migrated, vm) => {
if (getVMMigrationStatus(vm) === 'Succeeded') {
migrated.push(vm.id);
}
return migrated;
}, []);
const migratedVms = vmData.filter((vm) => migratedVmIds?.includes(vm.vm.id));
const networkIdsUsedByMigratedVms =
sourceProvider?.spec?.type !== 'ovirt' ? getNetworksUsedBySelectedVms(migratedVms, []) : [];
const storageIdsUsedByMigratedVms = ['ovirt', 'openstack'].includes(sourceProvider?.spec?.type)
? []
: getStoragesUsedBySelectedVms({}, migratedVms, []);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

useMemo to prevent rendering and exporting to a util file

) : (
<Button
onClick={onClick}
variant="plain"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

u can use ButtonVariant from PF

* // ...other props
* />
*/
export function StandardPageWithExpansion<T>(props: StandardPageWithExpansionProps<T>) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please consist with arrow functions

const { toId, onExpand, expandedIds, ...rest } = props;

if (onExpand && (!toId || !expandedIds)) {
throw new Error('Missing required properties: toId, expandedIds');
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

do we have other places in code where UI is thowring?

* Contract:
* 1. IDs provided with toId() function are unique and constant in time
*/
export function withIdBasedExpansion<T>({
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

arrow function and please avoid nested components

@sgratch sgratch added the enhancement Categorizes issue or PR as related to a new feature. label Jan 17, 2025
Signed-off-by: Joachim Schuler <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement Categorizes issue or PR as related to a new feature.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants