const (
CsrHeaderName = "CSR"
- PkHeaderName = "PK"
+ PkHeaderName = "PK"
)
type CertServiceClient interface {
}
type CertServiceClientImpl struct {
- healthUrl string
+ healthUrl string
certificationUrl string
httpClient HTTPClient
}
TrustedCertificates []string `json:"trustedCertificates"`
}
+type ResponseException struct {
+ ErrorMessage string `json:"errorMessage"`
+}
+
func (client *CertServiceClientImpl) CheckHealth() error {
request, err := http.NewRequest("GET", client.healthUrl, nil)
if err != nil {
return err
}
- if response.StatusCode != 200 {
+ if response.StatusCode != http.StatusOK {
return fmt.Errorf("health check retured status code [%d]", response.StatusCode)
}
return nil
}
-
func (client *CertServiceClientImpl) GetCertificates(csr []byte, key []byte) (*CertificatesResponse, error) {
request, err := http.NewRequest("GET", client.certificationUrl, nil)
return nil, err
}
+ if response.StatusCode != http.StatusOK {
+ var responseException ResponseException
+ err = json.NewDecoder(response.Body).Decode(&responseException)
+ return nil, fmt.Errorf("CertService API returned status code [%d] and message [%s]",
+ response.StatusCode, responseException.ErrorMessage)
+ }
+
var certificatesResponse CertificatesResponse
err = json.NewDecoder(response.Body).Decode(&certificatesResponse)
if err != nil {
import (
"bytes"
"fmt"
+ "io"
"io/ioutil"
"net/http"
"testing"
responseJsonReader := ioutil.NopCloser(bytes.NewReader([]byte(responseJson)))
client := CertServiceClientImpl{
certificationUrl: certificationUrl,
- httpClient: &httpClientMock{
- DoFunc: func(req *http.Request) (response *http.Response, e error) {
- mockedResponse := &http.Response{
- Body: responseJsonReader,
- }
- return mockedResponse, nil
- },
- },
+ httpClient: getMockedClient(responseJsonReader, http.StatusOK),
}
response, _ := client.GetCertificates(testdata.CsrBytes, testdata.PkBytes)
assert.ElementsMatch(t, []string{"cert-0", "cert-1"}, response.CertificateChain)
assert.Error(t, err)
}
+func Test_GetCertificates_shouldReturnError_whenResponseOtherThan200(t *testing.T) {
+ responseJson := `{"errorMessage": "CertService API error"}`
+ responseJsonReader := ioutil.NopCloser(bytes.NewReader([]byte(responseJson)))
+ client := CertServiceClientImpl{
+ certificationUrl: certificationUrl,
+ httpClient: getMockedClient(responseJsonReader, http.StatusNotFound),
+ }
+ response, err := client.GetCertificates(testdata.CsrBytes, testdata.PkBytes)
+
+ assert.Nil(t, response)
+ assert.Error(t, err)
+}
+
func Test_CheckHealth_shouldReturnNil_whenHttpClientReturnsStatusCode200(t *testing.T) {
client := CertServiceClientImpl{
certificationUrl: certificationUrl,
assert.Error(t, err)
}
+func getMockedClient(responseJsonReader io.ReadCloser, responseCode int) *httpClientMock {
+ return &httpClientMock{
+ DoFunc: func(req *http.Request) (response *http.Response, e error) {
+ mockedResponse := &http.Response{
+ Body: responseJsonReader,
+ StatusCode: responseCode,
+ }
+ return mockedResponse, nil
+ },
+ }
+}
+
type httpClientMock struct {
DoFunc func(*http.Request) (*http.Response, error)
}