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

com.palantir.atlasdb.jepsen.PartitionByInvokeNameCheckerHelper Maven / Gradle / Ivy

There is a newer version: 0.1152.0
Show newest version
/*
 * (c) Copyright 2018 Palantir Technologies Inc. All rights reserved.
 *
 * 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.palantir.atlasdb.jepsen;

import com.palantir.atlasdb.jepsen.events.Checker;
import com.palantir.atlasdb.jepsen.events.Event;
import com.palantir.atlasdb.jepsen.events.InfoEvent;
import com.palantir.atlasdb.jepsen.events.InvokeEvent;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.function.Supplier;
import java.util.stream.Collectors;

public class PartitionByInvokeNameCheckerHelper implements Checker {
    private final Supplier checkerSupplier;

    public PartitionByInvokeNameCheckerHelper(Supplier checkerSupplier) {
        this.checkerSupplier = checkerSupplier;
    }

    @Override
    public CheckerResult check(List events) {
        Map> histories = partitionEventsByInvokeValue(events);
        List results = runCheckerOnEachHistory(histories.values());
        return combineResults(results);
    }

    private Map> partitionEventsByInvokeValue(List events) {
        Map> partitionedEvents = new HashMap<>();
        Map lastInvokeValueForProcess = new HashMap<>();
        for (Event event : events) {
            int process = event.process();
            if (event instanceof InvokeEvent) {
                InvokeEvent invokeEvent = (InvokeEvent) event;
                lastInvokeValueForProcess.put(process, invokeEvent.value());
            }
            String key = lastInvokeValueForProcess.getOrDefault(process, null);
            /*
             * Note that all InfoEvents get mapped to null
             */
            if (event instanceof InfoEvent) {
                key = null;
            }
            List history = partitionedEvents.getOrDefault(key, new ArrayList<>());
            history.add(event);
            partitionedEvents.put(key, history);
        }
        return partitionedEvents;
    }

    private List runCheckerOnEachHistory(Collection> histories) {
        return histories.stream().map(this::runChecker).collect(Collectors.toList());
    }

    private CheckerResult runChecker(List history) {
        Checker checker = checkerSupplier.get();
        return checker.check(history);
    }

    private CheckerResult combineResults(List results) {
        List allErrors =
                results.stream().flatMap(result -> result.errors().stream()).collect(Collectors.toList());
        boolean allValid = results.stream().allMatch(CheckerResult::valid);
        return ImmutableCheckerResult.builder()
                .valid(allValid)
                .errors(allErrors)
                .build();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy