/**
* Copyright 2015-2017 Linagora, Université Joseph Fourier, Floralis
*
* The present code is developed in the scope of the joint LINAGORA -
* Université Joseph Fourier - Floralis research program and is designated
* as a "Result" pursuant to the terms and conditions of the LINAGORA
* - Université Joseph Fourier - Floralis research program. Each copyright
* holder of Results enumerated here above fully & independently holds complete
* ownership of the complete Intellectual Property rights applicable to the whole
* of said Results, and may freely exploit it in any manner which does not infringe
* the moral rights of the other copyright holders.
*
* 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 net.roboconf.core.commands;
import java.io.File;
import java.util.List;
import net.roboconf.core.Constants;
import net.roboconf.core.ErrorCode;
import net.roboconf.core.internal.tests.TestApplication;
import net.roboconf.core.model.ParsingError;
import net.roboconf.core.utils.Utils;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.TemporaryFolder;
/**
* @author Vincent Zurczak - Linagora
*/
public class ExecuteCommandInstructionTest {
@Rule
public TemporaryFolder folder = new TemporaryFolder();
private static final String INVOKED_NAME = "to invoke";
private static final String INVOKER_NAME = "invokes";
private File cmdToExecute;
private Context context;
@Before
public void initialize() throws Exception {
TestApplication app = new TestApplication();
app.setDirectory( this.folder.newFolder());
File cmdDirectory = new File( app.getDirectory(), Constants.PROJECT_DIR_COMMANDS );
Assert.assertTrue( cmdDirectory.mkdirs());
this.cmdToExecute = new File( cmdDirectory, INVOKED_NAME + Constants.FILE_EXT_COMMANDS );
this.context = new Context( app, new File( cmdDirectory, INVOKER_NAME + Constants.FILE_EXT_COMMANDS ));
}
@Test
public void testValidate_1() {
String line = "execute ";
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 1, errors.size());
Assert.assertEquals( ErrorCode.CMD_MISSING_COMMAND_NAME, errors.get( 0 ).getErrorCode());
}
@Test
public void testValidate_2() {
String line = "execute inexisting";
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 1, errors.size());
Assert.assertEquals( ErrorCode.CMD_INEXISTING_COMMAND, errors.get( 0 ).getErrorCode());
}
@Test
public void testValidate_3() {
String line = "execute " + this.context.getCommandFile().getName();
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 1, errors.size());
Assert.assertEquals( ErrorCode.CMD_LOOPING_COMMAND, errors.get( 0 ).getErrorCode());
}
@Test
public void testValidate_4() {
String line = "execute " + INVOKER_NAME + " ";
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 1, errors.size());
Assert.assertEquals( ErrorCode.CMD_LOOPING_COMMAND, errors.get( 0 ).getErrorCode());
}
@Test
public void testValidate_5() {
String line = "execute " + this.cmdToExecute.getName();
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 1, errors.size());
Assert.assertEquals( ErrorCode.CMD_INEXISTING_COMMAND, errors.get( 0 ).getErrorCode());
}
@Test
public void testValidate_6() throws Exception {
Assert.assertTrue( this.cmdToExecute.createNewFile());
String line = "execute " + this.cmdToExecute.getName();
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 0, errors.size());
}
@Test
public void testValidate_7() throws Exception {
Assert.assertTrue( this.cmdToExecute.createNewFile());
String line = "execute " + INVOKED_NAME;
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 0, errors.size());
}
@Test
public void testValidate_8() throws Exception {
Assert.assertTrue( this.cmdToExecute.createNewFile());
String line = "excuse " + this.cmdToExecute.getName();
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 1, errors.size());
Assert.assertEquals( ErrorCode.CMD_INVALID_SYNTAX, errors.get( 0 ).getErrorCode());
}
@Test
public void testValidate_noContextFile_noRecursiveCommand() throws Exception {
// No context file
Assert.assertTrue( this.context.getCommandFile().createNewFile());
this.context = new Context( this.context.getApp(), null );
// Few lines before, the same test gives a LOOPING_COMMAND error.
// However, commands may not always be loaded from a file.
String line = "execute " + INVOKER_NAME;
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 0, errors.size());
}
@Test
public void testValidate_noContextFile_withRecursiveCommand() throws Exception {
// The commands file to execute contains the exact same instruction
Utils.writeStringInto( " eXecuTe " + INVOKER_NAME + ".commands ", this.context.getCommandFile());
// No context file
this.context = new Context( this.context.getApp(), null );
// Commands may not always be loaded from a file.
String line = "execute " + INVOKER_NAME;
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 1, errors.size());
Assert.assertEquals( ErrorCode.CMD_NASTY_LOOPING_COMMAND, errors.get( 0 ).getErrorCode());
}
@Test
public void testValidate_noContextFile_noRecursiveCommand_2() throws Exception {
// The commands file to execute contains the exact same instruction
Utils.writeStringInto( " eXecuTe " + INVOKED_NAME + "\n# " + INVOKER_NAME + ".commands ", this.context.getCommandFile());
// No context file
this.context = new Context( this.context.getApp(), null );
Assert.assertTrue( this.cmdToExecute.createNewFile());
// Commands may not always be loaded from a file.
String line = "execute " + INVOKER_NAME;
ExecuteCommandInstruction instr = new ExecuteCommandInstruction( this.context, line, 1 );
List<ParsingError> errors = instr.validate();
Assert.assertEquals( 0, errors.size());
}
}