/** * Copyright 2005-2016 Red Hat, Inc. * * Red Hat licenses this file to you 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 io.fabric8.arquillian.kubernetes.enricher; import io.fabric8.arquillian.kubernetes.Session; import io.fabric8.kubernetes.client.KubernetesClient; import io.fabric8.kubernetes.jolokia.JolokiaClients; import org.jboss.arquillian.core.api.Instance; import org.jboss.arquillian.core.api.annotation.Inject; import org.jboss.arquillian.test.api.ArquillianResource; import org.jboss.arquillian.test.spi.enricher.resource.ResourceProvider; import java.lang.annotation.Annotation; /** * A {@link org.jboss.arquillian.test.spi.enricher.resource.ResourceProvider} for {@link JolokiaClients}. * It injects the clients so it can be used to perform JMX based assertions on remote containers using jolokia. */ public class JolokiaClientsProvider implements ResourceProvider { @Inject private Instance<KubernetesClient> clientInstance; @Inject private Instance<Session> sessionInstance; @Override public boolean canProvide(Class<?> type) { return JolokiaClients.class.isAssignableFrom(type); } @Override public Object lookup(ArquillianResource resource, Annotation... qualifiers) { KubernetesClient client = this.clientInstance.get(); JolokiaClients jolokiaClients = new JolokiaClients(client); return jolokiaClients; } }