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

Implement FAT-15806 #4204

Merged
merged 68 commits into from
Sep 18, 2024
Merged
Changes from all commits
Commits
Show all changes
68 commits
Select commit Hold shift + click to select a range
b5b5f56
Fix extended tests Thunderjet
bohdanihor Apr 16, 2024
9168dee
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 16, 2024
a4e661c
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 18, 2024
9407007
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 19, 2024
9b4ae2d
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 21, 2024
f06d8f4
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 23, 2024
bc7fc6f
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 24, 2024
aa3ee21
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 24, 2024
0a83653
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 25, 2024
f6c7f3c
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Apr 29, 2024
e9f23bb
Rewrite big UI methods into one API
bohdanihor May 1, 2024
0b27fe6
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor May 1, 2024
5b4eb3a
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor May 29, 2024
2e6898b
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jun 9, 2024
fad93f6
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jun 17, 2024
4fa814d
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jun 18, 2024
0d0b1ce
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jun 19, 2024
562b6fa
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jun 19, 2024
5f4ee15
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jun 25, 2024
0d943b1
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jun 26, 2024
e439f6d
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jul 1, 2024
4521c3c
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jul 4, 2024
643bb89
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jul 4, 2024
dfcde3b
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jul 8, 2024
87098f0
Merge branch 'master' of https://github.com/folio-org/stripes-testing
bohdanihor Jul 8, 2024
af8b486
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 9, 2024
b6d5309
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 10, 2024
3b95943
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 11, 2024
950de63
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 15, 2024
aa232bd
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 18, 2024
24df5da
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 19, 2024
abb0c43
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 21, 2024
c55c964
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 24, 2024
1f2b369
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 24, 2024
b23eb1d
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 26, 2024
e6bd685
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 26, 2024
1000b10
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 26, 2024
e4cc749
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 29, 2024
9f26287
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 29, 2024
15482b9
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Jul 30, 2024
baf48e4
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 7, 2024
18a73d1
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 8, 2024
bf5d618
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 11, 2024
393e0cf
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 12, 2024
1d0b6e8
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 12, 2024
0465f50
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 13, 2024
3b40565
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 14, 2024
6dc7eac
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 15, 2024
c7f6c52
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 19, 2024
3f17c6a
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 19, 2024
f290d30
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 22, 2024
a8a0bc2
Update tests after UIF-540
IhorBohdan Aug 23, 2024
2cb5f24
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Aug 23, 2024
bef911c
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 3, 2024
0bb842e
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 4, 2024
52a24ee
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 4, 2024
54e7a47
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 9, 2024
c93b465
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 10, 2024
efd5c76
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 11, 2024
55c7d0e
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 12, 2024
d9db6a1
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 12, 2024
d6a0ce2
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 13, 2024
d627632
Merge branch 'master' of https://github.com/folio-org/stripes-testing
IhorBohdan Sep 16, 2024
9be6e6b
Implement FAT-15806
IhorBohdan Sep 16, 2024
ff5ae82
Merge branch 'master' into FAT-15806
IhorBohdan Sep 17, 2024
5cf19e4
Merge branch 'master' into FAT-15806
IhorBohdan Sep 17, 2024
34ffefe
Merge branch 'master' into FAT-15806
IhorBohdan Sep 18, 2024
f6aa210
Merge branch 'master' into FAT-15806
IhorBohdan Sep 18, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,243 @@
import uuid from 'uuid';
import permissions from '../../../support/dictionary/permissions';
import FiscalYears from '../../../support/fragments/finance/fiscalYears/fiscalYears';
import Funds from '../../../support/fragments/finance/funds/funds';
import Ledgers from '../../../support/fragments/finance/ledgers/ledgers';
import Invoices from '../../../support/fragments/invoices/invoices';
import OrderLines from '../../../support/fragments/orders/orderLines';
import Orders from '../../../support/fragments/orders/orders';
import NewOrganization from '../../../support/fragments/organizations/newOrganization';
import Organizations from '../../../support/fragments/organizations/organizations';
import NewLocation from '../../../support/fragments/settings/tenant/locations/newLocation';
import ServicePoints from '../../../support/fragments/settings/tenant/servicePoints/servicePoints';
import TopMenu from '../../../support/fragments/topMenu';
import Users from '../../../support/fragments/users/users';
import Budgets from '../../../support/fragments/finance/budgets/budgets';
import {
ACQUISITION_METHOD_NAMES_IN_PROFILE,
INVOICE_STATUSES,
ORDER_STATUSES,
} from '../../../support/constants';
import BasicOrderLine from '../../../support/fragments/orders/basicOrderLine';
import MaterialTypes from '../../../support/fragments/settings/inventory/materialTypes';
import Approvals from '../../../support/fragments/settings/invoices/approvals';

describe('Finance: Transactions', () => {
const defaultFiscalYear = { ...FiscalYears.defaultUiFiscalYear };
const firstLedger = {
...Ledgers.defaultUiLedger,
restrictEncumbrance: false,
restrictExpenditures: true,
};
const firstFund = { ...Funds.defaultUiFund };

const firstOrder = {
id: uuid(),
vendor: '',
orderType: 'One-Time',
approved: true,
reEncumber: true,
};
const firstBudget = {
...Budgets.getDefaultBudget(),
allocated: 100,
allowableEncumbrance: 100,
allowableExpenditure: 100,
};
const organization = { ...NewOrganization.defaultUiOrganizations };
const isApprovePayEnabled = true;
const isApprovePayDisabled = false;
let thirdInvoice;
let firstInvoice;
let secondInvoice;
let user;
let servicePointId;
let location;
let firstOrderNumber;

before(() => {
cy.getAdminToken();
// create first Fiscal Year and prepere 2 Funds for Rollover
FiscalYears.createViaApi(defaultFiscalYear).then((firstFiscalYearResponse) => {
defaultFiscalYear.id = firstFiscalYearResponse.id;
firstBudget.fiscalYearId = firstFiscalYearResponse.id;
firstLedger.fiscalYearOneId = defaultFiscalYear.id;
Ledgers.createViaApi(firstLedger).then((ledgerResponse) => {
firstLedger.id = ledgerResponse.id;
firstFund.ledgerId = firstLedger.id;

Funds.createViaApi(firstFund).then((fundResponse) => {
firstFund.id = fundResponse.fund.id;
firstBudget.fundId = fundResponse.fund.id;
Budgets.createViaApi(firstBudget);
cy.getAdminToken();
ServicePoints.getViaApi().then((servicePoint) => {
servicePointId = servicePoint[0].id;
NewLocation.createViaApi(NewLocation.getDefaultLocation(servicePointId)).then((res) => {
location = res;

MaterialTypes.createMaterialTypeViaApi(MaterialTypes.getDefaultMaterialType()).then(
(mtypes) => {
cy.getAcquisitionMethodsApi({
query: `value="${ACQUISITION_METHOD_NAMES_IN_PROFILE.PURCHASE_AT_VENDOR_SYSTEM}"`,
}).then((params) => {
// Prepare 2 Open Orders for Rollover
Organizations.createOrganizationViaApi(organization).then(
(responseOrganizations) => {
organization.id = responseOrganizations;
firstOrder.vendor = organization.id;
const firstOrderLine = {
...BasicOrderLine.defaultOrderLine,
cost: {
listUnitPrice: 10,
currency: 'USD',
discountType: 'percentage',
quantityPhysical: 1,
poLineEstimatedPrice: 10,
},
fundDistribution: [
{ code: firstFund.code, fundId: firstFund.id, value: 100 },
],
locations: [
{ locationId: location.id, quantity: 1, quantityPhysical: 1 },
],
acquisitionMethod: params.body.acquisitionMethods[0].id,
physical: {
createInventory: 'Instance, Holding, Item',
materialType: mtypes.body.id,
materialSupplier: responseOrganizations,
volumes: [],
},
};

Orders.createOrderViaApi(firstOrder).then((firstOrderResponse) => {
firstOrder.id = firstOrderResponse.id;
firstOrderLine.purchaseOrderId = firstOrderResponse.id;
firstOrderNumber = firstOrderResponse.poNumber;

OrderLines.createOrderLineViaApi(firstOrderLine);
Orders.updateOrderViaApi({
...firstOrderResponse,
workflowStatus: ORDER_STATUSES.OPEN,
});
});
Invoices.createInvoiceWithInvoiceLineViaApi({
vendorId: organization.id,
fiscalYearId: defaultFiscalYear.id,
fundDistributions: firstOrderLine.fundDistribution,
accountingCode: organization.erpCode,
releaseEncumbrance: true,
subTotal: 15,
}).then((invoiceResponse) => {
firstInvoice = invoiceResponse;

Invoices.changeInvoiceStatusViaApi({
invoice: firstInvoice,
status: INVOICE_STATUSES.APPROVED,
});
});

Invoices.createInvoiceWithInvoiceLineViaApi({
vendorId: organization.id,
fiscalYearId: defaultFiscalYear.id,
fundDistributions: firstOrderLine.fundDistribution,
accountingCode: organization.erpCode,
releaseEncumbrance: true,
subTotal: -20,
}).then((secondInvoiceResponse) => {
secondInvoice = secondInvoiceResponse;

Invoices.changeInvoiceStatusViaApi({
invoice: secondInvoice,
status: INVOICE_STATUSES.PAID,
});
});

Invoices.createInvoiceViaApi({
vendorId: organization.id,
accountingCode: organization.erpCode,
}).then((thirdInvoiceResponse) => {
thirdInvoice = thirdInvoiceResponse;

OrderLines.getOrderLineViaApi({
query: `poLineNumber=="*${firstOrderNumber}*"`,
}).then((orderLines) => {
const firstInvoiceLine = Invoices.getDefaultInvoiceLine({
invoiceId: thirdInvoice.id,
invoiceLineStatus: thirdInvoice.status,
fundDistributions: orderLines[0].fundDistribution,
accountingCode: organization.erpCode,
quantity: 1,
subTotal: 16,
});
Invoices.createInvoiceLineViaApi(firstInvoiceLine);

const secondInvoiceLine = Invoices.getDefaultInvoiceLine({
invoiceId: thirdInvoice.id,
invoiceLineStatus: thirdInvoice.status,
fundDistributions: orderLines[0].fundDistribution,
accountingCode: organization.erpCode,
quantity: 1,
subTotal: -10,
});
Invoices.createInvoiceLineViaApi(secondInvoiceLine);

const thirdInvoiceLine = Invoices.getDefaultInvoiceLine({
invoiceId: thirdInvoice.id,
invoiceLineStatus: thirdInvoice.status,
fundDistributions: orderLines[0].fundDistribution,
accountingCode: organization.erpCode,
quantity: 1,
subTotal: 100,
});
Invoices.createInvoiceLineViaApi(thirdInvoiceLine);
Approvals.setApprovePayValue(isApprovePayEnabled);
});
});
},
);
});
},
);
});
});
});
});
});

cy.createTempUser([
permissions.uiFinanceViewFundAndBudget.gui,
permissions.uiInvoicesApproveInvoices.gui,
permissions.uiInvoicesPayInvoices.gui,
permissions.uiInvoicesCanViewAndEditInvoicesAndInvoiceLines.gui,
]).then((userProperties) => {
user = userProperties;
cy.login(userProperties.username, userProperties.password, {
path: TopMenu.invoicesPath,
waiter: Invoices.waitLoading,
});
});
});

after(() => {
cy.getAdminToken();
Approvals.setApprovePayValue(isApprovePayDisabled);
Users.deleteViaApi(user.userId);
});

it(
'C496167 Invoice with three invoice lines (including credit) can NOT be paid when available expenditure balance is less that invoice total (thunderjet)',
{ tags: ['criticalPath', 'thunderjet'] },
() => {
Invoices.searchByNumber(thirdInvoice.vendorInvoiceNo);
Invoices.selectInvoice(thirdInvoice.vendorInvoiceNo);
Invoices.canNotApproveAndPayInvoice(
`One or more Fund distributions on this invoice can not be paid, because there is not enough money in [${firstFund.code}].`,
);
Invoices.selectInvoiceLineByNumber('$16.00');
Invoices.openPageFundInInvoiceLine(`${firstFund.name}(${firstFund.code})`);
Funds.viewTransactionsForCurrentBudget();
Funds.checkAbsentTransaction('Payment');
},
);
});
Loading