mirror of
https://github.com/bringout/oca-ocb-pos.git
synced 2026-04-24 19:02:08 +02:00
19.0 vanilla
This commit is contained in:
parent
6e54c1af6c
commit
3ca647e428
1087 changed files with 132065 additions and 108499 deletions
|
|
@ -0,0 +1,86 @@
|
|||
import { test, expect } from "@odoo/hoot";
|
||||
import { setupPosEnv } from "@point_of_sale/../tests/unit/utils";
|
||||
import { definePosModels } from "@point_of_sale/../tests/unit/data/generate_model_definitions";
|
||||
import { patchWithCleanup } from "@web/../tests/web_test_helpers";
|
||||
|
||||
definePosModels();
|
||||
|
||||
test("createNewOrder", async () => {
|
||||
const store = await setupPosEnv();
|
||||
store.addNewOrder();
|
||||
const order = store.getOrder();
|
||||
expect(order.employee_id.id).toBe(2);
|
||||
});
|
||||
test("employeeIsAdmin", async () => {
|
||||
const store = await setupPosEnv();
|
||||
const emp = store.models["hr.employee"].get(2);
|
||||
store.setCashier(emp);
|
||||
expect(store.employeeIsAdmin).toBe(true);
|
||||
});
|
||||
test("_getConnectedCashier", async () => {
|
||||
const store = await setupPosEnv();
|
||||
expect(store._getConnectedCashier().id).toBe(2);
|
||||
});
|
||||
test("shouldShowOpeningControl", async () => {
|
||||
const store = await setupPosEnv();
|
||||
const emp = store.models["hr.employee"].get(2);
|
||||
store.setCashier(emp);
|
||||
store.hasLoggedIn = true;
|
||||
expect(store.shouldShowOpeningControl()).toBe(true);
|
||||
});
|
||||
test("allowProductCreation", async () => {
|
||||
const store = await setupPosEnv();
|
||||
const admin = store.models["hr.employee"].get(2);
|
||||
store.setCashier(admin);
|
||||
expect(await store.allowProductCreation()).toBe(true);
|
||||
const emp = store.models["hr.employee"].get(3);
|
||||
store.setCashier(emp);
|
||||
expect(await store.allowProductCreation()).toBe(false);
|
||||
});
|
||||
test("addLineToCurrentOrder", async () => {
|
||||
const store = await setupPosEnv();
|
||||
store.addNewOrder();
|
||||
const admin = store.models["hr.employee"].get(2);
|
||||
store.setCashier(admin);
|
||||
const product_id = store.models["product.product"].get(5);
|
||||
const result = await store.addLineToCurrentOrder({
|
||||
product_id: product_id,
|
||||
product_tmpl_id: product_id.product_tmpl_id,
|
||||
});
|
||||
expect(result.order_id.employee_id.id).toBe(2);
|
||||
});
|
||||
test("canEditPayment", async () => {
|
||||
const store = await setupPosEnv();
|
||||
store.addNewOrder();
|
||||
const order = store.getOrder();
|
||||
const admin = store.models["hr.employee"].get(2);
|
||||
store.setCashier(admin);
|
||||
expect(store.canEditPayment(order)).toBe(true);
|
||||
const emp = store.models["hr.employee"].get(3);
|
||||
store.setCashier(emp);
|
||||
expect(store.canEditPayment(order)).toBe(false);
|
||||
});
|
||||
test("handleUrlParams prevents unauthorized access when POS is locked with pos_hr", async () => {
|
||||
const store = await setupPosEnv();
|
||||
store.config.module_pos_hr = true;
|
||||
odoo.from_backend = false;
|
||||
|
||||
store.resetCashier();
|
||||
expect(store.cashier).toBe(false);
|
||||
expect(store.config.module_pos_hr).toBe(true);
|
||||
store.router.state.current = "ProductScreen";
|
||||
store.router.state.params = {};
|
||||
|
||||
let navigateCalledWithLoginScreen = false;
|
||||
patchWithCleanup(store.router, {
|
||||
navigate(routeName, routeParams) {
|
||||
if (routeName === "LoginScreen") {
|
||||
navigateCalledWithLoginScreen = true;
|
||||
}
|
||||
return super.navigate(routeName, routeParams);
|
||||
},
|
||||
});
|
||||
|
||||
await store.handleUrlParams();
|
||||
expect(navigateCalledWithLoginScreen).toBe(true);
|
||||
});
|
||||
Loading…
Add table
Add a link
Reference in a new issue