/* * Copyright 2017 TWO SIGMA OPEN SOURCE, LLC * * 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.twosigma.beaker.jupyter.handler; import com.twosigma.beaker.KernelTest; import com.twosigma.beaker.evaluator.EvaluatorTest; import com.twosigma.beaker.jupyter.msg.JupyterMessages; import com.twosigma.jupyter.message.Header; import org.assertj.core.api.Assertions; import org.junit.After; import org.junit.Before; import org.junit.BeforeClass; import org.junit.Test; import com.twosigma.jupyter.message.Message; import java.util.LinkedHashMap; import java.util.List; import static com.twosigma.beaker.jupyter.msg.JupyterMessages.EXECUTE_REPLY; import static com.twosigma.jupyter.message.MessageSerializer.parse; import static com.twosigma.jupyter.message.MessageSerializer.toJson; public class ExecuteRequestHandlerTest { private static KernelTest kernel; private ExecuteRequestHandler executeRequestHandler; private Message message; private Message magicMessage; @BeforeClass public static void setUpClass(){ kernel = new KernelTest("sid", new EvaluatorTest()){ @Override public void publish(Message message) { super.publish(copyMessage(message)); } }; } @Before public void setUp() { executeRequestHandler = new ExecuteRequestHandler(kernel); message = JupyterHandlerTest.initExecuteRequestMessage(); magicMessage = JupyterHandlerTest.initExecuteRequestMessage(); magicMessage.getContent().put("code", "%lsmagic"); } @After public void tearDown() throws Exception { kernel.clearPublishedMessages(); } @Test public void handleMessage_shouldSendTwoMessages() throws Exception { //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Assertions.assertThat(kernel.getPublishedMessages().size()).isEqualTo(2); } @Test public void handleMessage_firstSentMessageHasExecutionStateIsBusy() throws Exception { //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(0); Assertions.assertThat(publishMessage.getContent().get("execution_state")).isEqualTo("busy"); } @Test public void handleMessage_firstSentMessageHasSessionId() throws Exception { //given String expectedSessionId = message.getHeader().getSession(); //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(0); Assertions.assertThat(publishMessage.getHeader().getSession()).isEqualTo(expectedSessionId); } @Test public void handleMessage_firstSentMessageHasTypeIsStatus() throws Exception { //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(0); Assertions.assertThat(publishMessage.getHeader().getType()) .isEqualTo(JupyterMessages.STATUS.getName()); } @Test public void handleMessage_firstSentMessageHasParentHeader() throws Exception { //given String expectedHeader = message.getHeader().asJson(); //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(0); Assertions.assertThat(publishMessage.getParentHeader().asJson()).isEqualTo(expectedHeader); } @Test public void handleMessage_firstSentMessageHasIdentities() throws Exception { //given String expectedIdentities = new String(message.getIdentities().get(0)); //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(0); Assertions.assertThat(new String(publishMessage.getIdentities().get(0))) .isEqualTo(expectedIdentities); } @Test public void handleMessage_secondSentMessageHasSessionId() throws Exception { //given String expectedSessionId = message.getHeader().getSession(); //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(1); Assertions.assertThat(publishMessage.getHeader().getSession()).isEqualTo(expectedSessionId); } @Test public void handleMessage_secondSendMessageHasTypeIsExecutionInput() throws Exception { //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(1); Assertions.assertThat(publishMessage.getHeader().getType()) .isEqualTo(JupyterMessages.EXECUTE_INPUT.getName()); } @Test public void handleMessage_secondSentMessageHasContentCode() throws Exception { //given String expectedCode = (String) message.getContent().get("code"); //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(1); Assertions.assertThat(publishMessage.getContent().get("code")).isEqualTo(expectedCode); } @Test public void handleMessage_secondSentMessageHasContentExecutionCount() throws Exception { //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(1); Assertions.assertThat(publishMessage.getContent().get("execution_count")).isNotNull(); } @Test public void handleMessage_secondSentMessageHasParentHeader() throws Exception { //given String expectedHeader = message.getHeader().asJson(); //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(1); Assertions.assertThat(publishMessage.getParentHeader().asJson()).isEqualTo(expectedHeader); } @Test public void handleMessage_secondSentMessageHasIdentities() throws Exception { //given String expectedIdentities = new String(message.getIdentities().get(0)); //when executeRequestHandler.handle(message); //then Assertions.assertThat(kernel.getPublishedMessages()).isNotEmpty(); Message publishMessage = kernel.getPublishedMessages().get(1); Assertions.assertThat(new String(publishMessage.getIdentities().get(0))) .isEqualTo(expectedIdentities); } @Test public void handleMagicMessage_executionStateStartsBusyEndsIdle() throws Exception { //when executeRequestHandler.handle(magicMessage); //then final List<Message> publishedMessages = kernel.getPublishedMessages(); Assertions.assertThat(publishedMessages).isNotEmpty(); Message firstPublishedMessage = publishedMessages.get(0); Assertions.assertThat(firstPublishedMessage.getContent().get("execution_state")).isEqualTo("busy"); Message lastPublishedMessage = publishedMessages.get(publishedMessages.size() - 1); Assertions.assertThat(lastPublishedMessage.getContent().get("execution_state")).isEqualTo("idle"); } @Test public void handleMagicMessage_replyIsSent() throws Exception { //when executeRequestHandler.handle(magicMessage); //then final List<Message> sentMessages = kernel.getSentMessages(); Assertions.assertThat(sentMessages).isNotEmpty(); Message firstSentMessage = sentMessages.get(0); Assertions.assertThat(firstSentMessage.getHeader().getTypeEnum()).isEqualTo(EXECUTE_REPLY); } private static Message copyMessage(Message origin) { Message copy = new Message(); for (byte[] list : origin.getIdentities()) { copy.getIdentities().add(list.clone()); } String header = toJson(origin.getHeader()); String parent = toJson(origin.getParentHeader()); String metadata = toJson(origin.getMetadata()); String content = toJson(origin.getContent()); copy.setHeader(parse(header, Header.class)); copy.setParentHeader(parse(parent, Header.class)); copy.setMetadata(parse(metadata, LinkedHashMap.class)); copy.setContent(parse(content, LinkedHashMap.class)); return copy; } }