How to use PulsarContainer class of org.testcontainers.containers package

Best Testcontainers-java code snippet using org.testcontainers.containers.PulsarContainer

Source:PulsarContainerRuntime.java Github

copy

Full Screen

...22import org.slf4j.Logger;23import org.slf4j.LoggerFactory;24import org.testcontainers.containers.BindMode;25import org.testcontainers.containers.GenericContainer;26import org.testcontainers.containers.PulsarContainer;27import org.testcontainers.containers.output.Slf4jLogConsumer;28import org.testcontainers.containers.wait.strategy.HttpWaitStrategy;29import org.testcontainers.utility.DockerImageName;30import java.io.IOException;31import java.time.Duration;32import static org.apache.flink.util.DockerImageVersions.PULSAR;33import static org.apache.flink.util.Preconditions.checkNotNull;34import static org.testcontainers.containers.PulsarContainer.BROKER_HTTP_PORT;35import static org.testcontainers.containers.PulsarContainer.BROKER_PORT;36/**37 * {@link PulsarRuntime} implementation, use the TestContainers as the backend. We would start a38 * pulsar container by this provider.39 */40public class PulsarContainerRuntime implements PulsarRuntime {41 private static final Logger LOG = LoggerFactory.getLogger(PulsarContainerRuntime.class);42 private static final String PULSAR_INTERNAL_HOSTNAME = "pulsar";43 // This url is used on the container side.44 public static final String PULSAR_SERVICE_URL =45 String.format("pulsar://%s:%d", PULSAR_INTERNAL_HOSTNAME, BROKER_PORT);46 // This url is used on the container side.47 public static final String PULSAR_ADMIN_URL =48 String.format("http://%s:%d", PULSAR_INTERNAL_HOSTNAME, BROKER_HTTP_PORT);49 /**50 * Create a pulsar container provider by a predefined version, this constance {@link51 * DockerImageVersions#PULSAR} should be bumped after the new pulsar release.52 */53 private final PulsarContainer container = new PulsarContainer(DockerImageName.parse(PULSAR));54 private PulsarRuntimeOperator operator;55 public PulsarContainerRuntime bindWithFlinkContainer(GenericContainer<?> flinkContainer) {56 this.container57 .withNetworkAliases(PULSAR_INTERNAL_HOSTNAME)58 .dependsOn(flinkContainer)59 .withNetwork(flinkContainer.getNetwork());60 return this;61 }62 @Override63 public void startUp() {64 // Prepare Pulsar Container.65 container.withClasspathResourceMapping(66 "containers/txnStandalone.conf",67 "/pulsar/conf/standalone.conf",68 BindMode.READ_ONLY);69 container.addExposedPort(2181);...

Full Screen

Full Screen

PulsarContainer

Using AI Code Generation

copy

Full Screen

1import org.testcontainers.containers.PulsarContainer;2import org.apache.pulsar.client.api.PulsarClient;3import org.apache.pulsar.client.api.PulsarClientException;4import org.apache.pulsar.client.api.Producer;5import org.apache.pulsar.client.api.Consumer;6import org.apache.pulsar.client.api.Message;7import org.apache.pulsar.client.api.SubscriptionType;8import org.apache.pulsar.client.api.Schema;9public class PulsarClientExample {10 public static void main(String[] args) throws PulsarClientException {11 PulsarContainer pulsarContainer = new PulsarContainer();12 pulsarContainer.start();13 String pulsarBrokerUrl = pulsarContainer.getPulsarBrokerUrl();14 PulsarClient client = PulsarClient.builder()15 .serviceUrl(pulsarBrokerUrl)16 .build();17 Producer<String> producer = client.newProducer(Schema.STRING)18 .topic(topicName)19 .create();20 Consumer<String> consumer = client.newConsumer(Schema.STRING)21 .topic(topicName)22 .subscriptionName("my-subscription")23 .subscriptionType(SubscriptionType.Exclusive)24 .subscribe();25 producer.send("Hello Pulsar!");26 Message<String> msg = consumer.receive();27 System.out.println("Received message: " + msg.getValue());28 consumer.acknowledge(msg);29 client.close();30 pulsarContainer.stop();31 }32}

Full Screen

Full Screen

PulsarContainer

Using AI Code Generation

copy

Full Screen

1package org.testcontainers.containers;2public class PulsarContainer extends GenericContainer<PulsarContainer> {3 public static final String NAME = "apachepulsar/pulsar";4 public static final String TAG = "2.7.0";5 public static final Integer PULSAR_PORT = 6650;6 public static final Integer HTTP_PORT = 8080;7 public PulsarContainer() {8 this(NAME + ":" + TAG);9 }10 public PulsarContainer(String dockerImageName) {11 super(dockerImageName);12 withExposedPorts(PULSAR_PORT, HTTP_PORT);13 waitingFor(Wait.forListeningPort());14 }15 public String getPulsarBrokerUrl() {16 }17 public String getPulsarHttpUrl() {18 }19}20import org.testcontainers.containers.PulsarContainer;21import org.testcontainers.junit.jupiter.Container;22import org.testcontainers.junit.jupiter.Testcontainers;23public class PulsarContainerTest {24 public static PulsarContainer pulsarContainer = new PulsarContainer();25 public void testPulsarContainer() {26 String pulsarBrokerUrl = pulsarContainer.getPulsarBrokerUrl();27 String pulsarHttpUrl = pulsarContainer.getPulsarHttpUrl();28 System.out.println("Pulsar broker url: " + pulsarBrokerUrl);29 System.out.println("Pulsar http url: " + pulsarHttpUrl);30 }31}

Full Screen

Full Screen

PulsarContainer

Using AI Code Generation

copy

Full Screen

1public class PulsarContainer extends GenericContainer<PulsarContainer> {2 private static final String IMAGE_NAME = "apachepulsar/pulsar:2.7.1";3 private static final int PULSAR_PORT = 6650;4 private static final int HTTP_PORT = 8080;5 public PulsarContainer() {6 this(IMAGE_NAME);7 }8 public PulsarContainer(String imageName) {9 super(imageName);10 addExposedPorts(PULSAR_PORT, HTTP_PORT);11 }12 public String getPulsarBrokerUrl() {13 }14 public String getPulsarHttpUrl() {15 }16}17package org.testcontainers.pulsar;18import org.junit.jupiter.api.Test;19import org.testcontainers.containers.PulsarContainer;20public class PulsarContainerTest {21 public void testPulsarContainer() {22 PulsarContainer container = new PulsarContainer();23 container.start();24 System.out.println("Pulsar broker URL: " + container.getPulsarBrokerUrl());25 System.out.println("Pulsar HTTP URL: " + container.getPulsarHttpUrl());26 container.stop();27 }28}

Full Screen

Full Screen

PulsarContainer

Using AI Code Generation

copy

Full Screen

1import org.testcontainers.containers.PulsarContainer2PulsarContainer pulsarContainer = new PulsarContainer();3pulsarContainer.start();4String serviceUrl = pulsarContainer.getServiceUrl();5String httpServiceUrl = pulsarContainer.getHttpServiceUrl();6String adminUrl = pulsarContainer.getAdminUrl();7String brokerUrl = pulsarContainer.getBrokerUrl();8String brokerWebUrl = pulsarContainer.getBrokerWebUrl();9String webServiceUrl = pulsarContainer.getWebServiceUrl();10String webServiceUrlTls = pulsarContainer.getWebServiceUrlTls();11String zookeeperUrl = pulsarContainer.getZookeeperUrl();12String containerId = pulsarContainer.getContainerId();13String containerName = pulsarContainer.getContainerName();14String containerInfo = pulsarContainer.getContainerInfo();15String containerImage = pulsarContainer.getDockerImageName();16int containerPort = pulsarContainer.getMappedPort(6650);17int httpContainerPort = pulsarContainer.getMappedPort(8080);18int adminPort = pulsarContainer.getMappedPort(8081);19int brokerPort = pulsarContainer.getMappedPort(8082);20int brokerWebPort = pulsarContainer.getMappedPort(8083);21int webServicePort = pulsarContainer.getMappedPort(8084);22int webServiceTlsPort = pulsarContainer.getMappedPort(8085);23int zookeeperPort = pulsarContainer.getMappedPort(2181);24String containerLog = pulsarContainer.getLogs();25pulsarContainer.stop();26PulsarContainer pulsarContainer = new PulsarContainer("apachep

Full Screen

Full Screen

PulsarContainer

Using AI Code Generation

copy

Full Screen

1import org.apache.pulsar.client.api.*;2import org.testcontainers.containers.PulsarContainer;3import org.testcontainers.utility.DockerImageName;4import java.util.concurrent.TimeUnit;5public class PulsarContainerTest {6 public static void main(String[] args) throws PulsarClientException {7 PulsarContainer container = new PulsarContainer(DockerImageName.parse("apachepulsar/pulsar:2.7.0"));8 container.start();9 PulsarClient client = PulsarClient.builder()10 .serviceUrl(container.getHttpServiceUrl())11 .build();12 Producer<byte[]> producer = client.newProducer()13 .create();14 producer.send("Hello World!".getBytes());15 Consumer<byte[]> consumer = client.newConsumer()16 .subscriptionName("my-subscription")17 .subscribe();18 Message<byte[]> msg = consumer.receive(1, TimeUnit.SECONDS);19 System.out.println(msg.getValue());20 }21}

Full Screen

Full Screen

PulsarContainer

Using AI Code Generation

copy

Full Screen

1PulsarContainer pulsarContainer = new PulsarContainer()2 .withNamespace("public")3 .withClusterName("pulsar-cluster")4 .withConfigurationStore("pulsar-standalone")5 .withConfigurationStore("pulsar-standalone");6pulsarContainer.start();7PulsarAdmin pulsarAdmin = new PulsarAdminBuilder()8 .serviceHttpUrl(pulsarContainer.getHttpServiceUrl())9 .build();10pulsarAdmin.namespaces().createNamespace("public/default");11pulsarAdmin.namespaces().setNamespaceReplicationClusters("public/default", Sets.newHashSet("pulsar-cluster"));12pulsarAdmin.topics().createPartitionedTopic("public/default/my-topic", 4);13pulsarAdmin.topics().createSubscription("public/default/my-topic", "my-subscription", MessageId.latest);14pulsarAdmin.close();15pulsarContainer.stop();16PulsarContainer pulsarContainer = new PulsarContainer()17 .withConfigurationStore("pulsar-standalone")18 .withConfigurationStore("pulsar-standalone");19pulsarContainer.start();20PulsarAdmin pulsarAdmin = new PulsarAdminBuilder()21 .serviceHttpUrl(pulsarContainer.getHttpServiceUrl())22 .build();23pulsarAdmin.namespaces().createNamespace("public/default");24pulsarAdmin.namespaces().setNamespaceReplicationClusters("public/default", Sets.newHashSet("pulsar-cluster"));25pulsarAdmin.topics().createPartitionedTopic("public/default/my-topic", 4);26pulsarAdmin.topics().createSubscription("public/default/my-topic", "my-subscription", MessageId.latest);27pulsarAdmin.close();28pulsarContainer.stop();29PulsarContainer pulsarContainer = new PulsarContainer()30 .withConfigurationStore("pulsar-standalone")31 .withConfigurationStore("pulsar-standalone");32pulsarContainer.start();33PulsarAdmin pulsarAdmin = new PulsarAdminBuilder()34 .serviceHttpUrl(pulsarContainer.getHttpServiceUrl())35 .build();36pulsarAdmin.namespaces().createNamespace("public/default");37pulsarAdmin.namespaces().setNamespaceReplicationClusters("public/default", Sets.newHashSet("pulsar-cluster"));

Full Screen

Full Screen

PulsarContainer

Using AI Code Generation

copy

Full Screen

1import org.testcontainers.containers.PulsarContainer2import org.apache.pulsar.client.api.PulsarClient3import org.apache.pulsar.client.api.Message4import org.apache.pulsar.client.api.Consumer5import org.apache.pulsar.client.api.Producer6import org.apache.pulsar.client.api.Schema7def pulsarContainer = new PulsarContainer()8pulsarContainer.start()9def pulsarContainerUrl = pulsarContainer.getPulsarBrokerUrl()10def pulsarClient = PulsarClient.builder()11 .serviceUrl(pulsarContainerUrl)12 .build()13def consumer = pulsarClient.newConsumer(Schema.STRING)14 .topic("my-topic")15 .subscriptionName("my-subscription")16 .subscribe()17def producer = pulsarClient.newProducer(Schema.STRING)18 .topic("my-topic")19 .create()20producer.send("my-message")21def message = consumer.receive()22println(message.getValue())23consumer.close()24producer.close()25pulsarClient.close()26pulsarContainer.stop()

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Run Testcontainers-java automation tests on LambdaTest cloud grid

Perform automation testing on 3000+ real desktop and mobile devices online.

Test Your Web Or Mobile Apps On 3000+ Browsers

Signup for free

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful