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

com.gs.obevo.impl.command.ParallelDeployChangeCommand Maven / Gradle / Ivy

There is a newer version: 8.2.1
Show newest version
/**
 * Copyright 2017 Goldman Sachs.
 * 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.gs.obevo.impl.command;

import com.gs.obevo.api.appdata.Change;
import com.gs.obevo.api.appdata.ChangeKey;
import com.gs.obevo.api.appdata.DeployExecution;
import com.gs.obevo.api.platform.ChangeAuditDao;
import com.gs.obevo.api.platform.CommandExecutionContext;
import com.gs.obevo.impl.ChangeTypeBehaviorRegistry;
import com.gs.obevo.impl.ExecuteChangeCommand;
import org.apache.commons.lang3.ObjectUtils;
import org.eclipse.collections.api.block.function.Function;
import org.eclipse.collections.api.block.procedure.Procedure;
import org.eclipse.collections.api.collection.ImmutableCollection;
import org.eclipse.collections.api.list.ImmutableList;
import org.eclipse.collections.api.set.ImmutableSet;
import org.eclipse.collections.impl.factory.Sets;
import org.eclipse.collections.impl.parallel.ParallelIterate;

public class ParallelDeployChangeCommand implements ExecuteChangeCommand {
    private final String schema;
    private final int numThreads;
    private final ImmutableCollection changes;
    private boolean drop = false;
    private ImmutableSet dependencyChangeKeys;

    public ParallelDeployChangeCommand(String schema, ImmutableCollection changes, int numThreads) {
        this.changes = changes;
        this.schema = schema;
        this.numThreads = numThreads;
    }

    @Override
    public void execute(final ChangeTypeBehaviorRegistry changeTypeBehaviorRegistry, final CommandExecutionContext cec) {
        // 2 value -> only fork to parallelism if we have 2 tasks. 1 task will not require thread pool usage
        ParallelIterate.forEach(changes, new Procedure() {
            @Override
            public void value(Change change) {
                changeTypeBehaviorRegistry.deploy(change, cec);
            }
        }, 2, numThreads);
    }

    @Override
    public boolean isDrop() {
        return drop;
    }

    @Override
    public ExecuteChangeCommand withDrop(boolean drop) {
        this.drop = drop;
        return this;
    }

    @Override
    public String getSchema() {
        return schema;
    }

    @Override
    public void markAuditTable(ChangeTypeBehaviorRegistry changeTypeBehaviorRegistry, ChangeAuditDao artifactDeployerDao, DeployExecution deployExecution) {
        for (Change change : changes) {
            changeTypeBehaviorRegistry.manage(change, artifactDeployerDao, deployExecution);
        }
    }

    @Override
    public ImmutableList getChanges() {
        return (ImmutableList) changes.toList().toImmutable();
    }

    @Override
    public String getCommandDescription() {
        return "Parallel set of changes:\n" + changes.collect(new Function() {
            @Override
            public String valueOf(Change change) {
                return change.getDisplayString();
            }
        }).makeString("\n");
    }

    @Override
    public ImmutableSet getDependencyChangeKeys() {
        return ObjectUtils.firstNonNull(dependencyChangeKeys, Sets.immutable.empty());
    }

    @Override
    public void setDependencyChangeKeys(ImmutableSet dependencyChangeKeys) {
        this.dependencyChangeKeys = dependencyChangeKeys;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy