Skip to content

Commit

Permalink
test coverage
Browse files Browse the repository at this point in the history
Signed-off-by: Jeromy Cannon <jeromy@swirldslabs.com>
  • Loading branch information
jeromy-cannon committed Oct 2, 2023
1 parent d813231 commit d61a652
Show file tree
Hide file tree
Showing 5 changed files with 113 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -47,8 +47,6 @@ public static TestChartOptions defaults() {

@Override
public void apply(final HelmExecutionBuilder builder) {
builder.argument("output", "json");

if (filter() != null) {
builder.argument("filter", filter());
}
Expand Down
1 change: 1 addition & 0 deletions fullstack-helm-client/src/main/java/module-info.java
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
exports com.hedera.fullstack.helm.client.model;
exports com.hedera.fullstack.helm.client.model.chart;
exports com.hedera.fullstack.helm.client.model.install;
exports com.hedera.fullstack.helm.client.model.test;
exports com.hedera.fullstack.helm.client.execution;
exports com.hedera.fullstack.helm.client.proxy.request.chart to
com.hedera.fullstack.helm.client.test;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
import com.hedera.fullstack.helm.client.model.Repository;
import com.hedera.fullstack.helm.client.model.chart.Release;
import com.hedera.fullstack.helm.client.model.install.InstallChartOptions;
import com.hedera.fullstack.helm.client.model.test.TestChartOptions;
import com.jcovalent.junit.logging.JCovalentLoggingSupport;
import com.jcovalent.junit.logging.LogEntry;
import com.jcovalent.junit.logging.LogEntryBuilder;
Expand Down Expand Up @@ -344,4 +345,18 @@ void testInstallChartWithProvenanceValidation(final LoggingOutput loggingOutput)

testChartInstallWithCleanup(options, EXPECTED_LOG_ENTRIES, loggingOutput);
}

@Test
@DisplayName("Helm Test subcommand with options")
void testTestChartWithOptions() {
addRepoIfMissing(helmClient, HAPROXYTECH_REPOSITORY);
final TestChartOptions options =
TestChartOptions.builder().timeout("60s").filter("haproxy").build();
suppressExceptions(() -> helmClient.installChart(HAPROXY_RELEASE_NAME, HAPROXY_CHART));
try {
helmClient.testChart(HAPROXY_RELEASE_NAME, options);
} finally {
suppressExceptions(() -> helmClient.uninstallChart(HAPROXY_RELEASE_NAME));
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
/*
* Copyright (C) 2023 Hedera Hashgraph, LLC
*
* 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.hedera.fullstack.helm.client.test.model;

import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.mockito.ArgumentMatchers.anyString;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.verify;

import com.hedera.fullstack.helm.client.execution.HelmExecutionBuilder;
import com.hedera.fullstack.helm.client.model.test.TestChartOptions;
import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.mockito.Mock;
import org.mockito.junit.jupiter.MockitoExtension;

@ExtendWith(MockitoExtension.class)
class TestChartOptionsBuilderTest {
@Mock
private HelmExecutionBuilder builderMock;

@Test
@DisplayName("Test InstallChartOptionsBuilder")
void testInstallChartOptionsBuilder() {
TestChartOptions options =
TestChartOptions.builder().filter("filter").timeout("timeout").build();
assertNotNull(options);
assertEquals("timeout", options.timeout());
assertEquals("filter", options.filter());

options.apply(builderMock);

verify(builderMock, times(3)).argument(anyString(), anyString());
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
/*
* Copyright (C) 2023 Hedera Hashgraph, LLC
*
* 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.hedera.fullstack.helm.client.test.proxy.request.chart;

import static org.assertj.core.api.Assertions.assertThat;

import com.hedera.fullstack.helm.client.model.test.TestChartOptions;
import com.hedera.fullstack.helm.client.proxy.request.chart.ChartTestRequest;
import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.mockito.junit.jupiter.MockitoExtension;

@ExtendWith(MockitoExtension.class)
class ChartTestRequestTest {
@Test
@DisplayName("Test ChartTestRequest Chart constructor")
void testChartTestRequestChartConstructor() {
final ChartTestRequest chartTestRequest = new ChartTestRequest("apache");
assertThat(chartTestRequest.options()).isNotNull().isEqualTo(TestChartOptions.defaults());
assertThat(chartTestRequest.releaseName()).isEqualTo("apache");

final TestChartOptions opts =
TestChartOptions.builder().timeout("9m0s").filter("filter").build();
final ChartTestRequest nonDefaultOptRequest = new ChartTestRequest("apache", opts);

assertThat(nonDefaultOptRequest.options())
.isNotNull()
.isEqualTo(opts)
.isNotEqualTo(TestChartOptions.defaults());
}
}

0 comments on commit d61a652

Please sign in to comment.