mirror of
https://github.com/inventree/InvenTree.git
synced 2026-05-06 17:53:44 +00:00
[API] Monitor task (#11527)
* Enhance docstring * Return the ID of an offloaded task * Add API endpoint for background task detail * Add UI hook for monitoring background task progress * Handle queued tasks (not yet started) * Improve UX * Update frontend lib version * Bump API version * Fix notification * Simplify UI interface * Implement internal hook * Fix API path sequence * Add unit tests for task detail endpoint * Refactor code into reusable model * Explicit operation_id for API endpoints * Further refactoring * Use 200 response code - axios does not like 202, simplify it * Return task response for validation of part BOM * Fix schema * Cleanup * Run background worker during playwright tests - For full e2e integration testing * Improve hooks and unit testing * Rename custom hooks to meet react naming requirements
This commit is contained in:
@@ -140,6 +140,44 @@ test('Parts - BOM', async ({ browser }) => {
|
||||
await page.getByRole('button', { name: 'Close' }).click();
|
||||
});
|
||||
|
||||
/**
|
||||
* Perform BOM validation process
|
||||
* Note that this is a "background task" which is monitored by the "useBackgroundTask" hook
|
||||
*/
|
||||
test('Parts - BOM Validation', async ({ browser }) => {
|
||||
const page = await doCachedLogin(browser, { url: 'part/107/bom' });
|
||||
|
||||
// Run BOM validation step
|
||||
await page
|
||||
.getByRole('button', { name: 'action-button-validate-bom' })
|
||||
.click();
|
||||
await page.getByRole('button', { name: 'Submit' }).click();
|
||||
|
||||
// Background task monitoring
|
||||
await page.getByText('Validating BOM').waitFor();
|
||||
await page.getByText('BOM validated').waitFor();
|
||||
|
||||
await page.getByRole('button', { name: 'bom-validation-info' }).hover();
|
||||
await page.getByText('Validated By: allaccessAlly').waitFor();
|
||||
|
||||
// Edit line item, to ensure BOM is not valid next time around
|
||||
const cell = await page.getByRole('cell', { name: 'Red paint Red Paint' });
|
||||
await clickOnRowMenu(cell);
|
||||
await page.getByRole('menuitem', { name: 'Edit', exact: true }).click();
|
||||
|
||||
const input = await page.getByRole('textbox', {
|
||||
name: 'number-field-quantity'
|
||||
});
|
||||
|
||||
const value = await input.inputValue();
|
||||
|
||||
const nextValue = Number.parseFloat(value) + 0.24;
|
||||
|
||||
await input.fill(`${nextValue.toFixed(3)}`);
|
||||
await page.getByRole('button', { name: 'Submit' }).click();
|
||||
await page.getByText('BOM item updated').waitFor();
|
||||
});
|
||||
|
||||
test('Parts - Editing', async ({ browser }) => {
|
||||
const page = await doCachedLogin(browser, { url: 'part/104/details' });
|
||||
|
||||
|
||||
Reference in New Issue
Block a user