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

B 21904 nts oconus int #14384

Merged
merged 56 commits into from
Jan 13, 2025
Merged
Show file tree
Hide file tree
Changes from 51 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
4bcf62e
merged in latest int, added conflict error, adding tests
KonstanceH Dec 11, 2024
0427ed6
removing frontend for now
KonstanceH Dec 11, 2024
c828828
syntax fixes and working on tests
KonstanceH Dec 12, 2024
89ef13e
removing added error logic and its handling
KonstanceH Dec 12, 2024
b3995e6
testing
KonstanceH Dec 12, 2024
a143a1e
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 12, 2024
6ad5618
testing
KonstanceH Dec 12, 2024
cd85f86
adding invalid check for more coverage
KonstanceH Dec 12, 2024
e3998b3
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 12, 2024
e24834f
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 12, 2024
76845c0
fix ordering
KonstanceH Dec 13, 2024
aab9454
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 13, 2024
70387dd
working comments
KonstanceH Dec 16, 2024
8939bec
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 16, 2024
2cea7b1
merge in latest integration and fix conflicts
KonstanceH Dec 16, 2024
ac35b27
Merge branch 'main' into MAIN-B-21905-rename-nts-shipment-type
taeJungCaci Dec 18, 2024
d4e4194
add int changes and generate new migration file
KonstanceH Dec 18, 2024
d33ce66
merge in latest intergration and fix conflicts
KonstanceH Dec 18, 2024
1445b44
merge in from main branch
KonstanceH Dec 18, 2024
d5104e5
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 18, 2024
00a926a
Merge branch 'main' into B-21904-NTS-OCONUS-MAIN
KonstanceH Dec 19, 2024
03eb128
adding comments for re_services
KonstanceH Dec 19, 2024
c1b1719
Merge branch 'B-21904-NTS-OCONUS-MAIN' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 19, 2024
77e7371
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 19, 2024
97c84a2
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 19, 2024
bb1c9a9
add oconus to conus test and hook change
KonstanceH Dec 20, 2024
a801998
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Dec 20, 2024
d7445b5
wrong test
KonstanceH Dec 20, 2024
1aef072
flipped tests lol
KonstanceH Dec 20, 2024
2dd1c15
added test
KonstanceH Dec 20, 2024
2e08f26
Merge branch 'main' into B-21904-NTS-OCONUS-MAIN
KonstanceH Dec 20, 2024
08332c3
fixed asserts
KonstanceH Dec 20, 2024
0efdd54
should be it
KonstanceH Dec 20, 2024
5b90246
merge in main and fix conflicts
KonstanceH Jan 7, 2025
6449f4d
maybe fix factory for oconus to conus
KonstanceH Jan 7, 2025
6c4191b
merge in latest main and fix conflicts and linter change
KonstanceH Jan 7, 2025
b5e5c22
update factory test
KonstanceH Jan 7, 2025
8728368
merging in latest integration and fix conflicts and linter change
KonstanceH Jan 7, 2025
ad87679
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Jan 7, 2025
b466fde
adding in main changes
KonstanceH Jan 7, 2025
aeed165
adding back function logic from int overwrite
KonstanceH Jan 7, 2025
810761a
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Jan 7, 2025
d5632df
removed extra loop and put check at top of func
KonstanceH Jan 8, 2025
bb25ee3
merge in latest int and fix conlflicts
KonstanceH Jan 8, 2025
d098c80
ub got removed from the list?
KonstanceH Jan 8, 2025
a1c8dad
add in nil/type check
KonstanceH Jan 8, 2025
73103dc
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Jan 8, 2025
27d0535
generate swagger
KonstanceH Jan 8, 2025
212af35
added nts/nil checks
KonstanceH Jan 8, 2025
802c6c5
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Jan 9, 2025
35c16af
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Jan 9, 2025
4ee0dbe
remove breaking type change
KonstanceH Jan 9, 2025
46a4f80
trying to find why tests are brekaing?
KonstanceH Jan 9, 2025
214c4ff
changing file completely back
KonstanceH Jan 10, 2025
ba7dc65
this is weird
KonstanceH Jan 10, 2025
de0ebe6
Merge branch 'integrationTesting' into B-21904-NTS-OCONUS-INT
KonstanceH Jan 13, 2025
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
1 change: 1 addition & 0 deletions migrations/app/migrations_manifest.txt
Original file line number Diff line number Diff line change
Expand Up @@ -1060,6 +1060,7 @@
20241217180136_add_AK_zips_to_zip3_distances.up.sql
20241217191012_update_move_to_gbloc_for_ak.up.sql
20241218201833_add_PPPO_BASE_ELIZABETH.up.sql
20241218204620_add_international_nts_service_items.up.sql
20241220171035_add_additional_AK_zips_to_zip3_distances.up.sql
20241220213134_add_destination_gbloc_db_function.up.sql
20241224172258_add_and_update_po_box_zip.up.sql
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
--
-- Add service items for international NTS shipments.
--
INSERT INTO re_service_items
(id, service_id, shipment_type, market_code, is_auto_approved, created_at, updated_at, sort)
VALUES
--ISLH International Shipping & Linehaul
('2a560507-db09-4be1-b809-49c0f515b31b', '9f3d551a-0725-430e-897e-80ee9add3ae9' ,'HHG_INTO_NTS', 'i', true, now(), now(), 1),
--PODFSC International POD Fuel Surcharge
('e702818f-defd-452c-81a3-865b902e7dd0', '388115e8-abe9-441d-96cf-a39f24baa0a3' ,'HHG_INTO_NTS', 'i', true, now(), now(), 2),
danieljordan-caci marked this conversation as resolved.
Show resolved Hide resolved
--INPK International NTS packing
('366ee5a4-eb61-4ded-a68c-ddc29fe1a886', '874cb86a-bc39-4f57-a614-53ee3fcacf14' ,'HHG_INTO_NTS', 'i', true, now(), now(), 3),
--ICRT International crating
('aac4e95e-27ed-4f09-9b6b-384d8542f410', '86203d72-7f7c-49ff-82f0-5b95e4958f60' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IDASIT International destination add'l day SIT
('010f2f91-7381-4149-8d74-8eb5f593a864', '806c6d59-57ff-4a3f-9518-ebf29ba9cb10' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IDDSIT International destination SIT delivery
('a41966b7-b83a-4eaf-8e68-d5e884777102', '28389ee1-56cf-400c-aa52-1501ecdd7c69' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IDFSIT International destination 1st day SIT
('14c77957-3c76-465a-bb07-c98d36ef1e54', 'bd6064ca-e780-4ab4-a37b-0ae98eebb244' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IDSHUT International destination shuttle service
('d52d2d03-100a-4ed9-b2de-16eac63a375f', '22fc07ed-be15-4f50-b941-cbd38153b378' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IOASIT International origin add'l day SIT
('7fd91408-7d69-4375-b7e6-5b2ff714206b', 'bd424e45-397b-4766-9712-de4ae3a2da36' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IOFSIT International origin 1st day SIT
('b3dc509d-d652-4300-a702-a1ddce6255b6', 'b488bf85-ea5e-49c8-ba5c-e2fa278ac806' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IOPSIT International origin SIT pickup
('001eadb6-3526-45b9-96e0-0648bb481e86', '6f4f6e31-0675-4051-b659-89832259f390' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IOSHUT International origin shuttle service
('b991c5c9-af2c-4146-b999-1d0bdf91de3f', '624a97c5-dfbf-4da9-a6e9-526b4f95af8d' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IUCRT International uncrating
('5a89315a-257b-4ef0-92cb-4c06aa6f1332', '4132416b-b1aa-42e7-98f2-0ac0a03e8a31' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IOFSC International Origin SIT Fuel Surcharge
('d4a98dea-a5f7-4b92-b5de-e6350ab07824', '81e29d0c-02a6-4a7a-be02-554deb3ee49e' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL),
--IDSFSC International Destination SIT Fuel Surcharge
('eaea90c2-93d3-4db9-89cd-23ac57ec9ce1', '690a5fc1-0ea5-4554-8294-a367b5daefa9' ,'HHG_INTO_NTS', 'i', false, now(), now(), NULL);
6 changes: 5 additions & 1 deletion pkg/factory/mto_shipment_factory.go
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ func buildMTOShipmentWithBuildType(db *pop.Connection, customs []Customization,
defaultStatus = models.MTOShipmentStatusDraft
buildStorageFacility = hasStorageFacilityCustom
shipmentHasPickupDetails = true
shipmentHasDeliveryDetails = false
shipmentHasDeliveryDetails = true
case mtoShipmentNTSR:
defaultShipmentType = models.MTOShipmentTypeHHGOutOfNTSDom
defaultStatus = models.MTOShipmentStatusDraft
Expand All @@ -83,6 +83,10 @@ func buildMTOShipmentWithBuildType(db *pop.Connection, customs []Customization,
MarketCode: defaultMarketCode,
}

if newMTOShipment.ShipmentType == models.MTOShipmentTypeHHGIntoNTS && newMTOShipment.StorageFacility != nil {
newMTOShipment.DestinationAddress = &newMTOShipment.StorageFacility.Address
}

if cMtoShipment.Status == models.MTOShipmentStatusApproved {
approvedDate := time.Date(GHCTestYear, time.March, 20, 0, 0, 0, 0, time.UTC)
newMTOShipment.ApprovedDate = &approvedDate
Expand Down
4 changes: 2 additions & 2 deletions pkg/factory/mto_shipment_factory_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -450,9 +450,9 @@ func (suite *FactorySuite) TestBuildMTOShipment() {
suite.NotNil(ntsShipment.PrimeActualWeight)
suite.Nil(ntsShipment.StorageFacility)
suite.NotNil(ntsShipment.ScheduledPickupDate)
suite.Nil(ntsShipment.RequestedDeliveryDate)
suite.NotNil(ntsShipment.RequestedDeliveryDate)
suite.Nil(ntsShipment.ActualDeliveryDate)
suite.Nil(ntsShipment.ScheduledDeliveryDate)
suite.NotNil(ntsShipment.ScheduledDeliveryDate)
})

suite.Run("Successful creation of NTSShipment with storage facility", func() {
Expand Down
22 changes: 11 additions & 11 deletions pkg/handlers/primeapiv3/payloads/model_to_payload.go
Original file line number Diff line number Diff line change
Expand Up @@ -1087,17 +1087,6 @@ func MTOShipment(mtoShipment *models.MTOShipment) *primev3messages.MTOShipment {
return payload
}

// PostalCodeToRateArea converts postalCode into RateArea model to payload
func PostalCodeToRateArea(postalCode *string, shipmentPostalCodeRateAreaMap map[string]services.ShipmentPostalCodeRateArea) *primev3messages.RateArea {
if postalCode == nil {
return nil
}
if ra, ok := shipmentPostalCodeRateAreaMap[*postalCode]; ok {
return &primev3messages.RateArea{ID: handlers.FmtUUID(ra.RateArea.ID), RateAreaID: &ra.RateArea.Code, RateAreaName: &ra.RateArea.Name}
}
return nil
}

// Takes the Port Location from the MTO Service item and sets it on the MTOShipmentsWithoutServiceObjects payload
func setPortsOnShipments(mtoServiceItems *models.MTOServiceItems, mtoShipments *primev3messages.MTOShipmentsWithoutServiceObjects) {
shipmentPodMap := make(map[string]*models.PortLocation)
Expand Down Expand Up @@ -1140,3 +1129,14 @@ func Port(portLocation *models.PortLocation) *primev3messages.Port {
Country: portLocation.Country.CountryName,
}
}

// PostalCodeToRateArea converts postalCode into RateArea model to payload
func PostalCodeToRateArea(postalCode *string, shipmentPostalCodeRateAreaMap map[string]services.ShipmentPostalCodeRateArea) *primev3messages.RateArea {
if postalCode == nil {
return nil
}
if ra, ok := shipmentPostalCodeRateAreaMap[*postalCode]; ok {
return &primev3messages.RateArea{ID: handlers.FmtUUID(ra.RateArea.ID), RateAreaID: &ra.RateArea.Code, RateAreaName: &ra.RateArea.Name}
}
return nil
}
16 changes: 9 additions & 7 deletions pkg/services/mto_shipment/mto_shipment_updater.go
Original file line number Diff line number Diff line change
Expand Up @@ -1138,13 +1138,15 @@ func reServiceCodesForShipment(shipment models.MTOShipment) []models.ReServiceCo
}
}
case models.MTOShipmentTypeHHGIntoNTS:
// Need to create: Dom Linehaul, Fuel Surcharge, Dom Origin Price, Dom Destination Price, Dom NTS Packing
return []models.ReServiceCode{
models.ReServiceCodeDLH,
models.ReServiceCodeFSC,
models.ReServiceCodeDOP,
models.ReServiceCodeDDP,
models.ReServiceCodeDNPK,
if shipment.MarketCode != models.MarketCodeInternational {
Copy link
Contributor

Choose a reason for hiding this comment

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

Thoughts on adding the international market code check at the top of this function? If none of this logic would ever apply to intl shipments it seems to make more sense to do that instead of adding it to each case.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

yea that makes sense I think I assumed it wouldn't work without the added handling of each case's international service items, but nothings breaking so I'm making this change and I'm gonna push it up now.

// Need to create: Dom Linehaul, Fuel Surcharge, Dom Origin Price, Dom Destination Price, Dom NTS Packing
return []models.ReServiceCode{
models.ReServiceCodeDLH,
models.ReServiceCodeFSC,
models.ReServiceCodeDOP,
models.ReServiceCodeDDP,
models.ReServiceCodeDNPK,
}
}
case models.MTOShipmentTypeHHGOutOfNTSDom:
// Need to create: Dom Linehaul, Fuel Surcharge, Dom Origin Price, Dom Destination Price, Dom Unpacking
Expand Down
105 changes: 105 additions & 0 deletions pkg/services/mto_shipment/mto_shipment_updater_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3445,3 +3445,108 @@ func (suite *MTOShipmentServiceSuite) TestUpdateStatusServiceItems() {
suite.Equal(models.ReServiceCodeDSH, serviceItems[0].ReService.Code)
})
}

func (suite *MTOShipmentServiceSuite) TestUpdateDomesticServiceItems() {

expectedReServiceCodes := []models.ReServiceCode{
models.ReServiceCodeDLH,
models.ReServiceCodeFSC,
models.ReServiceCodeDOP,
models.ReServiceCodeDDP,
models.ReServiceCodeDNPK,
}

var pickupAddress models.Address
var storageFacility models.StorageFacility
var mto models.Move

setupTestData := func() {
for i := range expectedReServiceCodes {
Copy link
Contributor

Choose a reason for hiding this comment

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

Is this loop needed?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

No I think I just copied this function from somewhere else and built on it and left it in lol It'll be removed on this next push

factory.FetchReServiceByCode(suite.DB(), expectedReServiceCodes[i])
}

pickupAddress = factory.BuildAddress(suite.DB(), []factory.Customization{
{
Model: models.Address{
StreetAddress1: "Test Street 1",
City: "Des moines",
State: "IA",
PostalCode: "50309",
IsOconus: models.BoolPointer(false),
},
},
}, nil)

storageFacility = factory.BuildStorageFacility(suite.DB(), []factory.Customization{
{
Model: models.Address{
StreetAddress1: "Test Street Adress 2",
City: "Des moines",
State: "IA",
PostalCode: "50314",
IsOconus: models.BoolPointer(false),
},
},
}, nil)

mto = factory.BuildMove(suite.DB(), []factory.Customization{
{
Model: models.Move{
Status: models.MoveStatusAPPROVED,
},
},
}, nil)
}

builder := query.NewQueryBuilder()
moveRouter := moveservices.NewMoveRouter()
planner := &mocks.Planner{}
planner.On("ZipTransitDistance",
mock.AnythingOfType("*appcontext.appContext"),
mock.Anything,
mock.Anything,
).Return(400, nil)
siCreator := mtoserviceitem.NewMTOServiceItemCreator(planner, builder, moveRouter, ghcrateengine.NewDomesticUnpackPricer(), ghcrateengine.NewDomesticPackPricer(), ghcrateengine.NewDomesticLinehaulPricer(), ghcrateengine.NewDomesticShorthaulPricer(), ghcrateengine.NewDomesticOriginPricer(), ghcrateengine.NewDomesticDestinationPricer(), ghcrateengine.NewFuelSurchargePricer())
updater := NewMTOShipmentStatusUpdater(builder, siCreator, planner)

suite.Run("Preapproved service items successfully added to domestic nts shipments", func() {
setupTestData()

shipment := factory.BuildMTOShipment(suite.DB(), []factory.Customization{
{
Model: mto,
LinkOnly: true,
},
{
Model: pickupAddress,
Type: &factory.Addresses.PickupAddress,
LinkOnly: true,
},
{
Model: storageFacility,
Type: &factory.StorageFacility,
LinkOnly: true,
},
{
Model: models.MTOShipment{
ShipmentType: models.MTOShipmentTypeHHGIntoNTS,
Status: models.MTOShipmentStatusSubmitted,
},
},
}, nil)

appCtx := suite.AppContextForTest()
eTag := etag.GenerateEtag(shipment.UpdatedAt)

updatedShipment, err := updater.UpdateMTOShipmentStatus(appCtx, shipment.ID, models.MTOShipmentStatusApproved, nil, nil, eTag)
suite.NoError(err)

serviceItems := models.MTOServiceItems{}
err = appCtx.DB().EagerPreload("ReService").Where("mto_shipment_id = ?", updatedShipment.ID).All(&serviceItems)
suite.NoError(err)

for i := 0; i < len(expectedReServiceCodes); i++ {
suite.Equal(expectedReServiceCodes[i], serviceItems[i].ReService.Code)
}
})
}
4 changes: 3 additions & 1 deletion pkg/services/mto_shipment/shipment_approver.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package mtoshipment

import (
"math"
"slices"

"github.com/gofrs/uuid"
"github.com/pkg/errors"
Expand Down Expand Up @@ -80,7 +81,8 @@ func (f *shipmentApprover) ApproveShipment(appCtx appcontext.AppContext, shipmen
transactionError := appCtx.NewTransaction(func(txnAppCtx appcontext.AppContext) error {
// create international shipment service items before approving
// we use a database proc to create the basic auto-approved service items
if shipment.ShipmentType == models.MTOShipmentTypeHHG && shipment.MarketCode == models.MarketCodeInternational {
internationalShipmentTypes := []models.MTOShipmentType{models.MTOShipmentTypeHHG, models.MTOShipmentTypeHHGIntoNTS}
if slices.Contains(internationalShipmentTypes, shipment.ShipmentType) && shipment.MarketCode == models.MarketCodeInternational {
err := models.CreateApprovedServiceItemsForShipment(appCtx.DB(), shipment)
if err != nil {
return err
Expand Down
Loading
Loading