public interface OrderEditByKeyGet extends MetaModelGetDsl<OrderEdit,OrderEdit,OrderEditByKeyGet,OrderEditExpansionModel<OrderEdit>>
OrderFixtures.withOrder(client(), order -> { OrderEditFixtures.withOrderEdit(client(), order.toReference(), orderEdit -> { OrderEdit queriedOrderEdit = client().executeBlocking(OrderEditByKeyGet.of(orderEdit.getKey())); Assertions.assertThat(queriedOrderEdit).isNotNull(); Assertions.assertThat(queriedOrderEdit.getKey()).isEqualTo(orderEdit.getKey()); }); });See the test code.
| Modifier and Type | Method and Description |
|---|---|
List<ExpansionPath<OrderEdit>> |
expansionPaths() |
static OrderEditByKeyGet |
of(String key) |
OrderEditByKeyGet |
plusExpansionPaths(ExpansionPath<OrderEdit> expansionPath)
Creates a new object with the properties of the old object but adds
expansionPath to the expansion paths. |
OrderEditByKeyGet |
withExpansionPaths(ExpansionPath<OrderEdit> expansionPath)
Creates a new object with the properties of the old object but replaces all expansion paths with a single
expansionPath. |
OrderEditByKeyGet |
withExpansionPaths(List<ExpansionPath<OrderEdit>> expansionPaths)
Creates a new object with the properties of the old object but replaces all expansion paths with
expansionPaths. |
deserializecanDeserialize, httpRequestIntentplusExpansionPaths, withExpansionPathsplusExpansionPaths, plusExpansionPaths, plusExpansionPaths, withExpansionPaths, withExpansionPathsstatic OrderEditByKeyGet of(String key)
List<ExpansionPath<OrderEdit>> expansionPaths()
expansionPaths in interface ExpansionPathContainer<OrderEdit>expansionPaths in interface ReferenceExpansionSupport<OrderEdit>OrderEditByKeyGet plusExpansionPaths(ExpansionPath<OrderEdit> expansionPath)
ReferenceExpansionDslexpansionPath to the expansion paths.
An example in the product projection context:
final ProductProjectionByIdGet fetch = ProductProjectionByIdGet.of("id", ProductProjectionType.CURRENT); assertThat(fetch.expansionPaths()).isEmpty(); final ProductProjectionByIdGet fetch2 = fetch.plusExpansionPaths(ProductProjectionExpansionModel.of().categories()); assertThat(fetch.expansionPaths()).overridingErrorMessage("old object is unchanged").isEmpty(); assertThat(fetch2.expansionPaths()).isEqualTo(asList(ExpansionPath.of("categories[*]"))); assertThat(fetch2).isNotSameAs(fetch);See the test code.
plusExpansionPaths in interface ReferenceExpansionDsl<OrderEdit,OrderEditByKeyGet>expansionPath - the new expansion path to add to the existing onesOrderEditByKeyGet withExpansionPaths(ExpansionPath<OrderEdit> expansionPath)
ReferenceExpansionDslexpansionPath.
An example in the product projection context:
final ProductProjectionByIdGet fetch = ProductProjectionByIdGet.of("id", ProductProjectionType.CURRENT) .withExpansionPaths(ProductProjectionExpansionModel.of().categories()); assertThat(fetch.expansionPaths()) .isEqualTo(asList(ExpansionPath.of("categories[*]"))); final ProductProjectionByIdGet fetch2 = fetch.withExpansionPaths(ProductProjectionExpansionModel.of().productType()); assertThat(fetch.expansionPaths()).overridingErrorMessage("old object is unchanged") .isEqualTo(asList(ExpansionPath.of("categories[*]"))); assertThat(fetch2.expansionPaths()).isEqualTo(asList(ExpansionPath.of("productType"))); assertThat(fetch2).isNotSameAs(fetch);See the test code.
This method also can be used to use the same expansions as in another request:
final ProductProjectionQuery query = ProductProjectionQuery.ofCurrent().withExpansionPaths(m -> m.categories()); final ProductProjectionSearch search = ProductProjectionSearch.ofCurrent().withExpansionPaths(query); assertThat(query.expansionPaths()) .hasSize(1) .as("reuse expansion spec from other request") .isEqualTo(search.expansionPaths());See the test code.
withExpansionPaths in interface ReferenceExpansionDsl<OrderEdit,OrderEditByKeyGet>expansionPath - the new expansion pathsOrderEditByKeyGet withExpansionPaths(List<ExpansionPath<OrderEdit>> expansionPaths)
ReferenceExpansionDslexpansionPaths.withExpansionPaths in interface ReferenceExpansionDsl<OrderEdit,OrderEditByKeyGet>expansionPaths - the new expansion paths