com.chutneytesting.action.http.HttpDeleteAction Maven / Gradle / Ivy
package com.chutneytesting.action.http;
import static com.chutneytesting.action.http.HttpActionHelper.httpCommonValidation;
import static com.chutneytesting.action.spi.time.Duration.parseToMs;
import static com.chutneytesting.action.spi.validation.Validator.getErrorsFrom;
import static java.util.Optional.ofNullable;
import com.chutneytesting.action.http.domain.HttpAction;
import com.chutneytesting.action.http.domain.HttpClient;
import com.chutneytesting.action.http.domain.HttpClientFactory;
import com.chutneytesting.action.spi.Action;
import com.chutneytesting.action.spi.ActionExecutionResult;
import com.chutneytesting.action.spi.injectable.Input;
import com.chutneytesting.action.spi.injectable.Logger;
import com.chutneytesting.action.spi.injectable.Target;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.function.Supplier;
import org.springframework.http.HttpHeaders;
import org.springframework.http.ResponseEntity;
public class HttpDeleteAction implements Action {
private static final String DEFAULT_TIMEOUT = "2000 ms";
private final Target target;
private final Logger logger;
private final String uri;
private final Map headers;
private final String timeout;
public HttpDeleteAction(Target target, Logger logger, @Input("uri") String uri, @Input("headers") Map headers, @Input("timeout") String timeout) {
this.target = target;
this.logger = logger;
this.uri = uri;
this.headers = headers != null ? headers : new HashMap<>();
this.timeout = ofNullable(timeout).orElse(DEFAULT_TIMEOUT);
}
@Override
public List validateInputs() {
return getErrorsFrom(
httpCommonValidation(target, timeout)
);
}
@Override
public ActionExecutionResult execute() {
HttpClient httpClient = new HttpClientFactory().create(logger, target, String.class, (int) parseToMs(timeout));
HttpHeaders httpHeaders = new HttpHeaders();
headers.forEach((key, value) -> httpHeaders.add(key, value));
Supplier> caller = () -> httpClient.delete(this.uri, httpHeaders);
return HttpAction.httpCall(logger, caller);
}
}