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

com.vmware.xenon.common.fsm.TaskFSMTracker Maven / Gradle / Ivy

There is a newer version: 1.6.18
Show newest version
/*
 * Copyright (c) 2014-2015 VMware, 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.vmware.xenon.common.fsm;

import java.util.EnumSet;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;

import com.vmware.xenon.common.TaskState.TaskStage;

/**
 * A Finite State Machine implementation for TaskStage.
 * A client does not need to explicitly invoke this class' configure(), only instantiate the class.
 */
public class TaskFSMTracker extends FSMTracker implements TaskFSM {

    public TaskFSMTracker() {
        Map> config = new HashMap<>();

        // create states
        for (TaskStage s : EnumSet.allOf(TaskStage.class)) {
            config.put(s, new HashMap<>());
        }

        // create transitions
        for (Entry> e : config.entrySet()) {
            Map transitions = e.getValue();

            switch (e.getKey()) {
            case CREATED:
                transitions.put(TaskStage.STARTED, TaskStage.STARTED);
                transitions.put(TaskStage.FAILED, TaskStage.FAILED);
                transitions.put(TaskStage.CANCELLED, TaskStage.CANCELLED);
                break;

            case STARTED:
                transitions.put(TaskStage.STARTED, TaskStage.STARTED);
                transitions.put(TaskStage.FINISHED, TaskStage.FINISHED);
                transitions.put(TaskStage.FAILED, TaskStage.FAILED);
                transitions.put(TaskStage.CANCELLED, TaskStage.CANCELLED);
                break;

            default:
                // note that FINISHED, FAILED and CANCELLED are terminal states
                break;
            }

            config.put(e.getKey(), transitions);
        }

        super.configure(config, TaskStage.CREATED);
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy