/* * SonarQube * Copyright (C) 2009-2017 SonarSource SA * mailto:info AT sonarsource DOT com * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package org.sonar.process; import java.util.Objects; import org.junit.Test; import static org.assertj.core.api.Assertions.assertThat; import static org.sonar.process.Lifecycle.State; import static org.sonar.process.Lifecycle.State.INIT; import static org.sonar.process.Lifecycle.State.OPERATIONAL; import static org.sonar.process.Lifecycle.State.RESTARTING; import static org.sonar.process.Lifecycle.State.STARTED; import static org.sonar.process.Lifecycle.State.STARTING; import static org.sonar.process.Lifecycle.State.STOPPING; import static org.sonar.process.Lifecycle.State.values; public class LifecycleTest { @Test public void equals_and_hashcode() { Lifecycle init = new Lifecycle(); assertThat(init.equals(init)).isTrue(); assertThat(init.equals(new Lifecycle())).isTrue(); assertThat(init.equals("INIT")).isFalse(); assertThat(init.equals(null)).isFalse(); assertThat(init.hashCode()).isEqualTo(new Lifecycle().hashCode()); // different state Lifecycle stopping = new Lifecycle(); stopping.tryToMoveTo(STARTING); assertThat(stopping).isNotEqualTo(init); } @Test public void try_to_move_does_not_support_jumping_states() { Lifecycle lifecycle = new Lifecycle(); assertThat(lifecycle.getState()).isEqualTo(INIT); assertThat(lifecycle.tryToMoveTo(STARTED)).isFalse(); assertThat(lifecycle.getState()).isEqualTo(INIT); assertThat(lifecycle.tryToMoveTo(STARTING)).isTrue(); assertThat(lifecycle.getState()).isEqualTo(STARTING); } @Test public void no_state_can_not_move_to_itself() { for (State state : values()) { assertThat(newLifeCycle(state).tryToMoveTo(state)).isFalse(); } } @Test public void can_move_to_STOPPING_from_STARTING_STARTED_OPERATIONAL_only() { for (State state : values()) { boolean tryToMoveTo = newLifeCycle(state).tryToMoveTo(STOPPING); if (state == STARTING || state == STARTED || state == OPERATIONAL) { assertThat(tryToMoveTo).describedAs("from state " + state).isTrue(); } else { assertThat(tryToMoveTo).describedAs("from state " + state).isFalse(); } } } @Test public void can_move_to_OPERATIONAL_from_STARTED_only() { for (State state : values()) { boolean tryToMoveTo = newLifeCycle(state).tryToMoveTo(OPERATIONAL); if (state == STARTED) { assertThat(tryToMoveTo).describedAs("from state " + state).isTrue(); } else { assertThat(tryToMoveTo).describedAs("from state " + state).isFalse(); } } } @Test public void can_move_to_STARTING_from_RESTARTING() { assertThat(newLifeCycle(RESTARTING).tryToMoveTo(STARTING)).isTrue(); } private static Lifecycle newLifeCycle(State state) { switch (state) { case INIT: return new Lifecycle(); case STARTING: return newLifeCycle(INIT, state); case STARTED: return newLifeCycle(STARTING, state); case OPERATIONAL: return newLifeCycle(STARTED, state); case RESTARTING: return newLifeCycle(OPERATIONAL, state); case STOPPING: return newLifeCycle(OPERATIONAL, state); case HARD_STOPPING: return newLifeCycle(STARTING, state); case STOPPED: return newLifeCycle(STOPPING, state); default: throw new IllegalArgumentException("Unsupported state " + state); } } private static Lifecycle newLifeCycle(State from, State to) { Lifecycle lifecycle; lifecycle = newLifeCycle(from); assertThat(lifecycle.tryToMoveTo(to)).isTrue(); return lifecycle; } private static final class Transition { private final State from; private final State to; private Transition(State from, State to) { this.from = from; this.to = to; } @Override public boolean equals(Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } Transition that = (Transition) o; return from == that.from && to == that.to; } @Override public int hashCode() { return Objects.hash(from, to); } @Override public String toString() { return "Transition{" + from + " => " + to + '}'; } } }