com.github.tomakehurst.wiremock.stubbing.InMemoryStubMappings Maven / Gradle / Ivy
/*
* Copyright (C) 2011 Thomas Akehurst
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.github.tomakehurst.wiremock.stubbing;
import com.github.tomakehurst.wiremock.common.FileSource;
import com.github.tomakehurst.wiremock.common.SingleRootFileSource;
import com.github.tomakehurst.wiremock.extension.ResponseDefinitionTransformer;
import com.github.tomakehurst.wiremock.http.Request;
import com.github.tomakehurst.wiremock.http.ResponseDefinition;
import com.github.tomakehurst.wiremock.matching.RequestMatcherExtension;
import com.github.tomakehurst.wiremock.verification.LoggedRequest;
import com.google.common.base.Optional;
import com.google.common.base.Predicate;
import com.google.common.collect.ImmutableList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.UUID;
import static com.github.tomakehurst.wiremock.common.LocalNotifier.notifier;
import static com.github.tomakehurst.wiremock.core.WireMockApp.FILES_ROOT;
import static com.github.tomakehurst.wiremock.http.ResponseDefinition.copyOf;
import static com.google.common.collect.Iterables.find;
import static com.google.common.collect.Iterables.tryFind;
public class InMemoryStubMappings implements StubMappings {
private final SortedConcurrentMappingSet mappings = new SortedConcurrentMappingSet();
private final Scenarios scenarios = new Scenarios();
private final Map customMatchers;
private final Map transformers;
private final FileSource rootFileSource;
public InMemoryStubMappings(Map customMatchers, Map transformers, FileSource rootFileSource) {
this.customMatchers = customMatchers;
this.transformers = transformers;
this.rootFileSource = rootFileSource;
}
public InMemoryStubMappings() {
this(Collections.emptyMap(),
Collections.emptyMap(),
new SingleRootFileSource("."));
}
@Override
public ServeEvent serveFor(Request request) {
StubMapping matchingMapping = find(
mappings,
mappingMatchingAndInCorrectScenarioState(request),
StubMapping.NOT_CONFIGURED);
scenarios.onStubServed(matchingMapping);
ResponseDefinition responseDefinition = applyTransformations(request,
matchingMapping.getResponse(),
ImmutableList.copyOf(transformers.values()));
return ServeEvent.of(
LoggedRequest.createFrom(request),
copyOf(responseDefinition),
matchingMapping
);
}
private ResponseDefinition applyTransformations(Request request,
ResponseDefinition responseDefinition,
List transformers) {
if (transformers.isEmpty()) {
return responseDefinition;
}
ResponseDefinitionTransformer transformer = transformers.get(0);
ResponseDefinition newResponseDef =
transformer.applyGlobally() || responseDefinition.hasTransformer(transformer) ?
transformer.transform(request, responseDefinition, rootFileSource.child(FILES_ROOT), responseDefinition.getTransformerParameters()) :
responseDefinition;
return applyTransformations(request, newResponseDef, transformers.subList(1, transformers.size()));
}
@Override
public void addMapping(StubMapping mapping) {
mappings.add(mapping);
scenarios.onStubMappingAddedOrUpdated(mapping, mappings);
}
@Override
public void removeMapping(StubMapping mapping) {
mappings.remove(mapping);
scenarios.onStubMappingRemoved(mapping, mappings);
}
@Override
public void editMapping(StubMapping stubMapping) {
final Optional optionalExistingMapping = tryFind(
mappings,
mappingMatchingUuid(stubMapping.getUuid())
);
if (!optionalExistingMapping.isPresent()) {
String msg = "StubMapping with UUID: " + stubMapping.getUuid() + " not found";
notifier().error(msg);
throw new RuntimeException(msg);
}
final StubMapping existingMapping = optionalExistingMapping.get();
stubMapping.setInsertionIndex(existingMapping.getInsertionIndex());
stubMapping.setDirty(true);
mappings.replace(existingMapping, stubMapping);
scenarios.onStubMappingAddedOrUpdated(stubMapping, mappings);
}
@Override
public void reset() {
mappings.clear();
scenarios.clear();
}
@Override
public void resetScenarios() {
scenarios.reset();
}
@Override
public List getAll() {
return ImmutableList.copyOf(mappings);
}
@Override
public Optional get(final UUID id) {
return tryFind(mappings, new Predicate() {
@Override
public boolean apply(StubMapping input) {
return input.getUuid().equals(id);
}
});
}
@Override
public List getAllScenarios() {
return scenarios.getAll();
}
private Predicate mappingMatchingAndInCorrectScenarioState(final Request request) {
return mappingMatchingAndInCorrectScenarioStateNew(request);
}
private Predicate mappingMatchingAndInCorrectScenarioStateNew(final Request request) {
return new Predicate() {
public boolean apply(StubMapping mapping) {
return mapping.getRequest().match(request, customMatchers).isExactMatch() &&
(mapping.isIndependentOfScenarioState() || scenarios.mappingMatchesScenarioState(mapping));
}
};
}
private Predicate mappingMatchingUuid(final UUID uuid) {
return new Predicate() {
@Override
public boolean apply(StubMapping input) {
return input.getUuid().equals(uuid);
}
};
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy