blob: 852c2f8c1cf23c6f448e78d476608a829b786751 [file] [log] [blame]
/**
* 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 org.apache.aurora.scheduler.http;
import java.util.List;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.ObjectNode;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMultimap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.ImmutableSetMultimap;
import com.google.common.collect.Iterators;
import com.google.common.collect.Multimap;
import org.apache.aurora.common.testing.easymock.EasyMockTest;
import org.apache.aurora.gen.AssignedTask;
import org.apache.aurora.gen.JobKey;
import org.apache.aurora.gen.TaskConfig;
import org.apache.aurora.scheduler.preemptor.PreemptionVictim;
import org.apache.aurora.scheduler.state.ClusterStateImpl;
import org.apache.aurora.scheduler.storage.entities.IAssignedTask;
import org.apache.aurora.scheduler.storage.entities.ITaskConfig;
import org.junit.Before;
import org.junit.Test;
import static org.apache.aurora.scheduler.http.State.taskKey;
import static org.easymock.EasyMock.expect;
import static org.junit.Assert.assertEquals;
public class StateTest extends EasyMockTest {
private ClusterStateImpl clusterState;
private State state;
@Before
public void setUp() {
clusterState = createMock(ClusterStateImpl.class);
state = new State(clusterState);
}
private Multimap<String, PreemptionVictim> createState(IAssignedTask... tasks) {
ImmutableMultimap.Builder<String, PreemptionVictim> victims = ImmutableSetMultimap.builder();
for (IAssignedTask task : tasks) {
victims.put(task.getSlaveId(), PreemptionVictim.fromTask(task));
}
return victims.build();
}
private IAssignedTask makeTask(String taskId, String agentId, TaskConfig taskConfig) {
return IAssignedTask.build(new AssignedTask()
.setSlaveId(agentId)
.setSlaveHost(agentId + "-host")
.setTaskId(taskId)
.setTask(taskConfig));
}
private static List<String> getAgentTasks(JsonNode tasks) {
return ImmutableList.copyOf(Iterators.transform(tasks.elements(), JsonNode::asText));
}
@Test
public void testJson() throws Exception {
TaskConfig task1 = new TaskConfig().setJob(new JobKey("role", "env", "job"));
TaskConfig task2 = new TaskConfig().setJob(new JobKey("role", "env", "job"));
TaskConfig task3 = new TaskConfig().setJob(new JobKey("role", "env", "another-job"));
String task1Key = taskKey(ITaskConfig.build(task1));
String task2Key = taskKey(ITaskConfig.build(task2));
String task3Key = taskKey(ITaskConfig.build(task3));
// Tests:
// Same task config on multiple hosts.
// Different tasks configs for the same job.
// Multiple job keys.
Multimap<String, PreemptionVictim> expected = createState(
makeTask("task1", "agent1", task1),
makeTask("task2", "agent1", task1),
makeTask("task3", "agent2", task2),
makeTask("task4", "agent3", task3),
makeTask("task5", "agent2", task1));
expect(clusterState.getSlavesToActiveTasks()).andReturn(expected);
control.replay();
JsonNode result = new ObjectMapper().readTree((String) state.getState().getEntity());
ObjectNode tasks = (ObjectNode) result.get("taskConfigs");
assertEquals(ImmutableSet.of(task1Key, task2Key, task3Key),
ImmutableSet.copyOf(tasks.fieldNames()));
JsonNode agents = result.get("agents");
assertEquals(ImmutableList.of(task1Key, task1Key), getAgentTasks(agents.get("agent1")));
assertEquals(ImmutableList.of(task2Key, task1Key), getAgentTasks(agents.get("agent2")));
assertEquals(ImmutableList.of(task3Key), getAgentTasks(agents.get("agent3")));
}
}