public interface ZoneByIdGet extends MetaModelGetDsl<Zone,Zone,ZoneByIdGet,ZoneExpansionModel<Zone>>
ZoneFixtures.withUpdateableZone(client(), zone -> { final Zone fetchedZone = client().executeBlocking(ZoneByIdGet.of(zone.getId())); assertThat(fetchedZone.getId()).isEqualTo(zone.getId()); return zone; }, CountryCode.BA);
See the test code.
Modifier and Type | Method and Description |
---|---|
List<ExpansionPath<Zone>> |
expansionPaths() |
static ZoneByIdGet |
of(Identifiable<Zone> resource) |
static ZoneByIdGet |
of(String id) |
ZoneByIdGet |
plusExpansionPaths(ExpansionPath<Zone> expansionPath)
Creates a new object with the properties of the old object but adds
expansionPath to the expansion paths. |
ZoneByIdGet |
withExpansionPaths(ExpansionPath<Zone> expansionPath)
Creates a new object with the properties of the old object but replaces all expansion paths with a single
expansionPath . |
ZoneByIdGet |
withExpansionPaths(List<ExpansionPath<Zone>> expansionPaths)
Creates a new object with the properties of the old object but replaces all expansion paths with
expansionPaths . |
deserialize
canDeserialize, httpRequestIntent
plusExpansionPaths, withExpansionPaths
plusExpansionPaths, plusExpansionPaths, plusExpansionPaths, withExpansionPaths, withExpansionPaths
static ZoneByIdGet of(String id)
static ZoneByIdGet of(Identifiable<Zone> resource)
List<ExpansionPath<Zone>> expansionPaths()
expansionPaths
in interface ExpansionPathContainer<Zone>
expansionPaths
in interface ReferenceExpansionSupport<Zone>
ZoneByIdGet plusExpansionPaths(ExpansionPath<Zone> expansionPath)
ReferenceExpansionDsl
expansionPath
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<Zone,ZoneByIdGet>
expansionPath
- the new expansion path to add to the existing onesZoneByIdGet withExpansionPaths(ExpansionPath<Zone> expansionPath)
ReferenceExpansionDsl
expansionPath
.
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<Zone,ZoneByIdGet>
expansionPath
- the new expansion pathsZoneByIdGet withExpansionPaths(List<ExpansionPath<Zone>> expansionPaths)
ReferenceExpansionDsl
expansionPaths
.withExpansionPaths
in interface ReferenceExpansionDsl<Zone,ZoneByIdGet>
expansionPaths
- the new expansion paths