Skip to content

Commit

Permalink
merge in latest int and fix conlflicts
Browse files Browse the repository at this point in the history
  • Loading branch information
KonstanceH committed Jan 8, 2025
2 parents d5632df + 7f0b037 commit bb25ee3
Show file tree
Hide file tree
Showing 5 changed files with 216 additions and 17 deletions.
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,6 +1087,17 @@ 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 @@ -1129,14 +1140,3 @@ 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
}
179 changes: 179 additions & 0 deletions pkg/services/mto_shipment/shipment_approver_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1013,6 +1013,185 @@ func (suite *MTOShipmentServiceSuite) TestApproveShipment() {
suite.NotNil(shipment.MoveTaskOrder.ExcessWeightQualifiedAt)
})

suite.Run("If the CONUS to OCONUS UB mtoShipment is approved successfully it should create pre approved mtoServiceItems", func() {
internationalShipment := factory.BuildMTOShipment(suite.AppContextForTest().DB(), []factory.Customization{
{
Model: models.Move{
Status: models.MoveStatusAPPROVED,
},
},
{
Model: models.Address{
StreetAddress1: "Tester Address",
City: "Des Moines",
State: "IA",
PostalCode: "50314",
IsOconus: models.BoolPointer(false),
},
Type: &factory.Addresses.PickupAddress,
},
{
Model: models.MTOShipment{
MarketCode: models.MarketCodeInternational,
Status: models.MTOShipmentStatusSubmitted,
ShipmentType: models.MTOShipmentTypeUnaccompaniedBaggage,
},
},
{
Model: models.Address{
StreetAddress1: "JBER",
City: "Anchorage",
State: "AK",
PostalCode: "99505",
IsOconus: models.BoolPointer(true),
},
Type: &factory.Addresses.DeliveryAddress,
},
}, nil)

internationalShipmentEtag := etag.GenerateEtag(internationalShipment.UpdatedAt)
shipmentApprover := suite.createApproveShipmentSubtestData().shipmentApprover
_, err := shipmentApprover.ApproveShipment(suite.AppContextForTest(), internationalShipment.ID, internationalShipmentEtag)
suite.NoError(err)

// Get created pre approved service items
var serviceItems []models.MTOServiceItem
err2 := suite.AppContextForTest().DB().EagerPreload("ReService").Where("mto_shipment_id = ?", internationalShipment.ID).Order("created_at asc").All(&serviceItems)
suite.NoError(err2)

expectedReserviceCodes := []models.ReServiceCode{
models.ReServiceCodeUBP,
models.ReServiceCodeIUBPK,
models.ReServiceCodeIUBUPK,
models.ReServiceCodePOEFSC,
}

suite.Equal(4, len(serviceItems))
for i := 0; i < len(serviceItems); i++ {
actualReServiceCode := serviceItems[i].ReService.Code
suite.True(slices.Contains(expectedReserviceCodes, actualReServiceCode), "Contains unexpected: "+actualReServiceCode.String())
}
})

suite.Run("If the OCONUS to CONUS UB mtoShipment is approved successfully it should create pre approved mtoServiceItems", func() {
internationalShipment := factory.BuildMTOShipment(suite.AppContextForTest().DB(), []factory.Customization{
{
Model: models.Move{
Status: models.MoveStatusAPPROVED,
},
},
{
Model: models.Address{
StreetAddress1: "JBER",
City: "Anchorage",
State: "AK",
PostalCode: "99505",
IsOconus: models.BoolPointer(true),
},
Type: &factory.Addresses.PickupAddress,
},
{
Model: models.MTOShipment{
MarketCode: models.MarketCodeInternational,
Status: models.MTOShipmentStatusSubmitted,
ShipmentType: models.MTOShipmentTypeUnaccompaniedBaggage,
},
},
{
Model: models.Address{
StreetAddress1: "Tester Address",
City: "Des Moines",
State: "IA",
PostalCode: "50314",
IsOconus: models.BoolPointer(false),
},
Type: &factory.Addresses.DeliveryAddress,
},
}, nil)

internationalShipmentEtag := etag.GenerateEtag(internationalShipment.UpdatedAt)
shipmentApprover := suite.createApproveShipmentSubtestData().shipmentApprover
_, err := shipmentApprover.ApproveShipment(suite.AppContextForTest(), internationalShipment.ID, internationalShipmentEtag)
suite.NoError(err)

// Get created pre approved service items
var serviceItems []models.MTOServiceItem
err2 := suite.AppContextForTest().DB().EagerPreload("ReService").Where("mto_shipment_id = ?", internationalShipment.ID).Order("created_at asc").All(&serviceItems)
suite.NoError(err2)

expectedReserviceCodes := []models.ReServiceCode{
models.ReServiceCodeUBP,
models.ReServiceCodeIUBPK,
models.ReServiceCodeIUBUPK,
models.ReServiceCodePODFSC,
}

suite.Equal(4, len(serviceItems))
for i := 0; i < len(serviceItems); i++ {
actualReServiceCode := serviceItems[i].ReService.Code
suite.True(slices.Contains(expectedReserviceCodes, actualReServiceCode), "Contains unexpected: "+actualReServiceCode.String())
}
})

suite.Run("If the OCONUS to OCONUS UB mtoShipment is approved successfully it should create pre approved mtoServiceItems", func() {
internationalShipment := factory.BuildMTOShipment(suite.AppContextForTest().DB(), []factory.Customization{
{
Model: models.Move{
Status: models.MoveStatusAPPROVED,
},
},
{
Model: models.Address{
StreetAddress1: "JBER",
City: "Anchorage",
State: "AK",
PostalCode: "99505",
IsOconus: models.BoolPointer(true),
},
Type: &factory.Addresses.PickupAddress,
},
{
Model: models.MTOShipment{
MarketCode: models.MarketCodeInternational,
Status: models.MTOShipmentStatusSubmitted,
ShipmentType: models.MTOShipmentTypeUnaccompaniedBaggage,
},
},
{
Model: models.Address{
StreetAddress1: "Tester Address",
City: "Fairbanks",
State: "AK",
PostalCode: "99701",
IsOconus: models.BoolPointer(true),
},
Type: &factory.Addresses.DeliveryAddress,
},
}, nil)

internationalShipmentEtag := etag.GenerateEtag(internationalShipment.UpdatedAt)
shipmentApprover := suite.createApproveShipmentSubtestData().shipmentApprover
_, err := shipmentApprover.ApproveShipment(suite.AppContextForTest(), internationalShipment.ID, internationalShipmentEtag)
suite.NoError(err)

// Get created pre approved service items
var serviceItems []models.MTOServiceItem
err2 := suite.AppContextForTest().DB().EagerPreload("ReService").Where("mto_shipment_id = ?", internationalShipment.ID).Order("created_at asc").All(&serviceItems)
suite.NoError(err2)

expectedReserviceCodes := []models.ReServiceCode{
models.ReServiceCodeUBP,
models.ReServiceCodeIUBPK,
models.ReServiceCodeIUBUPK,
}

suite.Equal(3, len(serviceItems))
for i := 0; i < len(serviceItems); i++ {
actualReServiceCode := serviceItems[i].ReService.Code
suite.True(slices.Contains(expectedReserviceCodes, actualReServiceCode), "Contains unexpected: "+actualReServiceCode.String())
}
})

suite.Run("Given invalid shipment error returned", func() {
invalidShipment := factory.BuildMTOShipment(suite.AppContextForTest().DB(), []factory.Customization{
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -59,12 +59,12 @@ function filterPortFuelSurcharge(shipment, autoApprovedItems) {
const { destinationAddress, pickupAddress } = shipment;
let filteredPortFuelSurchargeList = autoApprovedItems;
if (pickupAddress.isOconus) {
filteredPortFuelSurchargeList = autoApprovedItems.filter((serviceItem) => {
filteredPortFuelSurchargeList = filteredPortFuelSurchargeList.filter((serviceItem) => {
return serviceItem.serviceCode !== SERVICE_ITEM_CODES.POEFSC;
});
}
if (destinationAddress.isOconus) {
filteredPortFuelSurchargeList = autoApprovedItems.filter((serviceItem) => {
filteredPortFuelSurchargeList = filteredPortFuelSurchargeList.filter((serviceItem) => {
return serviceItem.serviceCode !== SERVICE_ITEM_CODES.PODFSC;
});
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -294,6 +294,13 @@ const intlUbOconusToConusShipment = {
destinationAddress,
};

const intlUbOconusToOconusShipment = {
shipmentType: SHIPMENT_OPTIONS.UNACCOMPANIED_BAGGAGE,
marketCode: MARKET_CODES.INTERNATIONAL,
pickupAddress: oconusPickupAddress,
destinationAddress: oconusDestinationAddress,
};

describe('Shipment Service Items Table', () => {
describe('renders the hhg longhaul shipment type with service items', () => {
it.each([
Expand Down Expand Up @@ -390,4 +397,17 @@ describe('Shipment Service Items Table', () => {
expect(screen.getByText(serviceItem)).toBeInTheDocument();
});
});

describe('renders the intl UB shipment type (OCONUS -> OCONUS) with service items', () => {
it.each([['International UB'], ['International UB pack'], ['International UB unpack']])(
'expects %s to be in the document',
async (serviceItem) => {
render(<ShipmentServiceItemsTable shipment={intlUbOconusToOconusShipment} />);
expect(
await screen.findByRole('heading', { name: 'Service items for this shipment 3 items', level: 4 }),
).toBeInTheDocument();
expect(screen.getByText(serviceItem)).toBeInTheDocument();
},
);
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -245,11 +245,11 @@ properties:
- 'i'
example: 'd'
description: 'Single-letter designator for domestic (d) or international (i) shipments'
portOfDebarkation:
$ref: '../../Port.yaml'
portOfEmbarkation:
$ref: '../../Port.yaml'
originRateArea:
$ref: 'RateArea.yaml'
destinationRateArea:
$ref: 'RateArea.yaml'
portOfDebarkation:
$ref: '../../Port.yaml'
portOfEmbarkation:
$ref: '../../Port.yaml'

0 comments on commit bb25ee3

Please sign in to comment.