Java tutorial
/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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.accumulo.shell.commands; import java.io.PrintWriter; import java.io.Writer; import java.lang.reflect.Field; import java.util.EnumSet; import org.apache.accumulo.core.client.AccumuloClient; import org.apache.accumulo.core.client.IteratorSetting; import org.apache.accumulo.core.client.admin.TableOperations; import org.apache.accumulo.core.iterators.IteratorUtil.IteratorScope; import org.apache.accumulo.core.iterators.SortedKeyValueIterator; import org.apache.accumulo.shell.Shell; import org.apache.accumulo.start.classloader.vfs.AccumuloVFSClassLoader; import org.apache.commons.cli.CommandLine; import org.easymock.EasyMock; import org.junit.Before; import org.junit.Test; import jline.console.ConsoleReader; public class SetIterCommandTest { private SetIterCommand cmd; @Before public void setup() { cmd = new SetIterCommand(); // Initialize that internal state cmd.getOptions(); } @Test public void addColumnAgeOffFilter() throws Exception { AccumuloClient client = EasyMock.createMock(AccumuloClient.class); CommandLine cli = EasyMock.createMock(CommandLine.class); Shell shellState = EasyMock.createMock(Shell.class); ConsoleReader reader = EasyMock.createMock(ConsoleReader.class); Writer out = EasyMock.createMock(PrintWriter.class); TableOperations tableOperations = EasyMock.createMock(TableOperations.class); // Command line parsing EasyMock.expect(cli.hasOption("all")).andReturn(true); EasyMock.expect(cli.hasOption("all")).andReturn(true); EasyMock.expect(cli.hasOption("all")).andReturn(true); EasyMock.expect(cli.hasOption("t")).andReturn(true); EasyMock.expect(cli.hasOption("t")).andReturn(true); EasyMock.expect(cli.getOptionValue("t")).andReturn("foo"); EasyMock.expect(cli.hasOption("ns")).andReturn(false); EasyMock.expect(cli.getOptionValue("p")).andReturn("21"); EasyMock.expect(cli.getOptionValue("class")) .andReturn("org.apache.accumulo.core.iterators.user.ColumnAgeOffFilter"); EasyMock.expect(cli.hasOption("ageoff")).andReturn(false); EasyMock.expect(cli.hasOption("regex")).andReturn(false); EasyMock.expect(cli.hasOption("reqvis")).andReturn(false); EasyMock.expect(cli.hasOption("vers")).andReturn(false); EasyMock.expect(cli.getOptionValue("n", null)).andReturn(null); // Loading the class EasyMock.expect(shellState.getClassLoader(cli, shellState)) .andReturn(AccumuloVFSClassLoader.getClassLoader()); // Set the output object Field field = reader.getClass().getSuperclass().getDeclaredField("out"); field.setAccessible(true); field.set(reader, out); // Parsing iterator options reader.flush(); EasyMock.expectLastCall().times(3); EasyMock.expect(shellState.getReader()).andReturn(reader); // Shell asking for negate option, we pass in an empty string to pickup the default value of // 'false' EasyMock.expect(reader.readLine(EasyMock.anyObject(String.class))).andReturn(""); // Shell asking for the unnamed option for the column (a:a) and the TTL (1) EasyMock.expect(reader.readLine(EasyMock.anyObject(String.class))).andReturn("a:a 1"); // Shell asking for another unnamed option; we pass in an empty string to signal that we are // done adding options EasyMock.expect(reader.readLine(EasyMock.anyObject(String.class))).andReturn(""); EasyMock.expect(shellState.getAccumuloClient()).andReturn(client); // Table exists EasyMock.expect(client.tableOperations()).andReturn(tableOperations); EasyMock.expect(tableOperations.exists("foo")).andReturn(true); // Testing class load EasyMock.expect(shellState.getAccumuloClient()).andReturn(client); EasyMock.expect(client.tableOperations()).andReturn(tableOperations); EasyMock.expect( tableOperations.testClassLoad("foo", "org.apache.accumulo.core.iterators.user.ColumnAgeOffFilter", SortedKeyValueIterator.class.getName())) .andReturn(true); // Attach iterator EasyMock.expect(shellState.getAccumuloClient()).andReturn(client); EasyMock.expect(client.tableOperations()).andReturn(tableOperations); tableOperations.attachIterator(EasyMock.eq("foo"), EasyMock.anyObject(IteratorSetting.class), EasyMock.eq(EnumSet.allOf(IteratorScope.class))); EasyMock.expectLastCall().once(); EasyMock.replay(client, cli, shellState, reader, tableOperations); cmd.execute( "setiter -all -p 21 -t foo" + " -class org.apache.accumulo.core.iterators.user.ColumnAgeOffFilter", cli, shellState); EasyMock.verify(client, cli, shellState, reader, tableOperations); } }