All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.playtika.test.kafka.properties.ZookeeperConfigurationProperties Maven / Gradle / Ivy

/*
* The MIT License (MIT)
*
* Copyright (c) 2020 Playtika
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
 */
package com.playtika.test.kafka.properties;

import com.playtika.test.common.properties.CommonContainerProperties;
import com.playtika.test.common.utils.ContainerUtils;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springframework.boot.context.properties.ConfigurationProperties;

import javax.annotation.PostConstruct;

@Data
@EqualsAndHashCode(callSuper = true)
@ConfigurationProperties("embedded.zookeeper")
public class ZookeeperConfigurationProperties extends CommonContainerProperties {

    public static final String ZOOKEEPER_BEAN_NAME = "zookeeper";

    protected String zookeeperConnect;
    protected String containerZookeeperConnect;
    protected int zookeeperPort = 0;
    protected int sessionTimeoutMs = 5_000;
    protected int socketTimeoutMs = 5_000;
    protected String dockerImage = "confluentinc/cp-zookeeper:5.5.1";
    protected FileSystemBind fileSystemBind = new FileSystemBind();

    /**
     * Zookeeper container port will be assigned automatically if free port is available.
     * Override this only if you are sure that specified port is free.
     */
    @PostConstruct
    private void init() {
        if (this.zookeeperPort == 0) {
            this.zookeeperPort = ContainerUtils.getAvailableMappingPort();
        }
    }

    @Data
    public static final class FileSystemBind {
        private boolean enabled = true;
        private String dataFolder = "target/embedded-zk-data";
        private String txnLogsFolder = "target/embedded-zk-txn-logs";
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy