mirror of
https://gitlab.com/mbugroup/lti-api.git
synced 2026-05-22 22:35:43 +00:00
adjust export format purchase and filter
This commit is contained in:
@@ -22,9 +22,8 @@ func TestBuildPurchaseExportWorkbookHeadersAndRows(t *testing.T) {
|
||||
nil,
|
||||
"catatan",
|
||||
[]entity.PurchaseItem{
|
||||
buildPurchaseItemForExportTest(11, "Pakan Starter", 1000000, "Location A"),
|
||||
buildPurchaseItemForExportTest(12, "Vitamin A", 350000, "Location B"),
|
||||
buildPurchaseItemForExportTest(11, "Pakan Starter", 0, ""),
|
||||
buildPurchaseItemForExportTest(11, "Pakan Starter", 500, 2, 1000000, "Location A", "kg"),
|
||||
buildPurchaseItemForExportTest(12, "Vitamin A", 350, 1, 350000, "Location B", "botol"),
|
||||
},
|
||||
),
|
||||
buildPurchaseForExportTest(
|
||||
@@ -37,7 +36,7 @@ func TestBuildPurchaseExportWorkbookHeadersAndRows(t *testing.T) {
|
||||
ptrApprovalAction(entity.ApprovalActionRejected),
|
||||
"",
|
||||
[]entity.PurchaseItem{
|
||||
buildPurchaseItemForExportTest(21, "Obat X", 75000, ""),
|
||||
buildPurchaseItemForExportTest(21, "Obat X", 75000, 1, 75000, "", ""),
|
||||
},
|
||||
),
|
||||
})
|
||||
@@ -51,16 +50,27 @@ func TestBuildPurchaseExportWorkbookHeadersAndRows(t *testing.T) {
|
||||
}
|
||||
defer file.Close()
|
||||
|
||||
// Verify all 19 headers
|
||||
expectedHeaders := map[string]string{
|
||||
"A1": "PR Number",
|
||||
"B1": "PO Number",
|
||||
"C1": "Tanggal PO",
|
||||
"D1": "Supplier",
|
||||
"E1": "Lokasi",
|
||||
"F1": "Status",
|
||||
"G1": "Grand Total",
|
||||
"H1": "Products",
|
||||
"I1": "Notes",
|
||||
"D1": "Tanggal Terima",
|
||||
"E1": "Supplier",
|
||||
"F1": "Lokasi",
|
||||
"G1": "Gudang",
|
||||
"H1": "Product",
|
||||
"I1": "Qty",
|
||||
"J1": "Satuan",
|
||||
"K1": "Price",
|
||||
"L1": "Total Produk",
|
||||
"M1": "Vendor Ekspedisi",
|
||||
"N1": "Qty Ekspedisi",
|
||||
"O1": "Price Ekspedisi",
|
||||
"P1": "Total Ekspedisi",
|
||||
"Q1": "Grand Total All",
|
||||
"R1": "Status",
|
||||
"S1": "Notes",
|
||||
}
|
||||
for cell, expected := range expectedHeaders {
|
||||
got, err := file.GetCellValue(purchaseExportSheetName, cell)
|
||||
@@ -72,24 +82,46 @@ func TestBuildPurchaseExportWorkbookHeadersAndRows(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
// Row 2: Purchase 1, Item 1 (Pakan Starter)
|
||||
assertPurchaseCellEquals(t, file, "A2", "PR-00011")
|
||||
assertPurchaseCellEquals(t, file, "B2", "PO-00011")
|
||||
assertPurchaseCellEquals(t, file, "C2", "22-04-2026")
|
||||
assertPurchaseCellEquals(t, file, "D2", "Supplier A")
|
||||
assertPurchaseCellEquals(t, file, "E2", "Location A")
|
||||
assertPurchaseCellEquals(t, file, "F2", "Manager Purchase")
|
||||
assertPurchaseCellEquals(t, file, "G2", "Rp 1.350.000")
|
||||
assertPurchaseCellEquals(t, file, "H2", "Pakan Starter, Vitamin A")
|
||||
assertPurchaseCellEquals(t, file, "I2", "catatan")
|
||||
assertPurchaseCellEquals(t, file, "E2", "Supplier A")
|
||||
assertPurchaseCellEquals(t, file, "F2", "Location A")
|
||||
assertPurchaseCellEquals(t, file, "H2", "Pakan Starter")
|
||||
assertPurchaseCellEquals(t, file, "J2", "kg")
|
||||
assertPurchaseCellEquals(t, file, "K2", "500")
|
||||
assertPurchaseCellEquals(t, file, "L2", "1000000")
|
||||
assertPurchaseCellEquals(t, file, "M2", "-")
|
||||
assertPurchaseCellEquals(t, file, "P2", "0")
|
||||
assertPurchaseCellEquals(t, file, "Q2", "1000000")
|
||||
assertPurchaseCellEquals(t, file, "R2", "Manager Purchase")
|
||||
assertPurchaseCellEquals(t, file, "S2", "catatan")
|
||||
|
||||
assertPurchaseCellEquals(t, file, "A3", "PR-00012")
|
||||
assertPurchaseCellEquals(t, file, "B3", "-")
|
||||
assertPurchaseCellEquals(t, file, "C3", "-")
|
||||
assertPurchaseCellEquals(t, file, "E3", "-")
|
||||
assertPurchaseCellEquals(t, file, "F3", "Ditolak")
|
||||
assertPurchaseCellEquals(t, file, "G3", "Rp 75.000")
|
||||
assertPurchaseCellEquals(t, file, "H3", "Obat X")
|
||||
assertPurchaseCellEquals(t, file, "I3", "-")
|
||||
// Row 3: Purchase 1, Item 2 (Vitamin A)
|
||||
assertPurchaseCellEquals(t, file, "A3", "PR-00011")
|
||||
assertPurchaseCellEquals(t, file, "H3", "Vitamin A")
|
||||
assertPurchaseCellEquals(t, file, "J3", "botol")
|
||||
assertPurchaseCellEquals(t, file, "L3", "350000")
|
||||
assertPurchaseCellEquals(t, file, "Q3", "350000")
|
||||
|
||||
// Row 4: Purchase 2, Item 1 (Obat X) — no location, rejected
|
||||
assertPurchaseCellEquals(t, file, "A4", "PR-00012")
|
||||
assertPurchaseCellEquals(t, file, "B4", "-")
|
||||
assertPurchaseCellEquals(t, file, "C4", "-")
|
||||
assertPurchaseCellEquals(t, file, "F4", "-")
|
||||
assertPurchaseCellEquals(t, file, "H4", "Obat X")
|
||||
assertPurchaseCellEquals(t, file, "J4", "-")
|
||||
assertPurchaseCellEquals(t, file, "L4", "75000")
|
||||
assertPurchaseCellEquals(t, file, "Q4", "75000")
|
||||
assertPurchaseCellEquals(t, file, "R4", "Ditolak")
|
||||
assertPurchaseCellEquals(t, file, "S4", "-")
|
||||
|
||||
// Row 5: SUM row — total produk=1425000, ekspedisi=0, grand total all=1425000
|
||||
assertPurchaseCellEquals(t, file, "A5", "TOTAL")
|
||||
assertPurchaseCellEquals(t, file, "L5", "1425000")
|
||||
assertPurchaseCellEquals(t, file, "P5", "0")
|
||||
assertPurchaseCellEquals(t, file, "Q5", "1425000")
|
||||
}
|
||||
|
||||
func assertPurchaseCellEquals(t *testing.T, file *excelize.File, cell, expected string) {
|
||||
@@ -144,13 +176,20 @@ func buildPurchaseForExportTest(
|
||||
}
|
||||
}
|
||||
|
||||
func buildPurchaseItemForExportTest(productID uint, productName string, totalPrice float64, locationName string) entity.PurchaseItem {
|
||||
func buildPurchaseItemForExportTest(productID uint, productName string, price, totalQty, totalPrice float64, locationName, uomName string) entity.PurchaseItem {
|
||||
uomID := uint(0)
|
||||
if uomName != "" {
|
||||
uomID = productID + 2000
|
||||
}
|
||||
item := entity.PurchaseItem{
|
||||
ProductId: productID,
|
||||
Price: price,
|
||||
TotalQty: totalQty,
|
||||
TotalPrice: totalPrice,
|
||||
Product: &entity.Product{
|
||||
Id: productID,
|
||||
Name: productName,
|
||||
Uom: entity.Uom{Id: uomID, Name: uomName},
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user