blob: 4c3bb4763d4ced21cce3fe0433603969d638b487 [file] [log] [blame]
/**
* 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.pig.newplan.logical.optimizer;
import static org.apache.pig.builtin.mock.Storage.tuple;
import static org.junit.Assert.assertEquals;
import java.util.List;
import org.apache.pig.PigServer;
import org.apache.pig.builtin.mock.Storage;
import org.apache.pig.builtin.mock.Storage.Data;
import org.apache.pig.data.Tuple;
import org.apache.pig.test.Util;
import org.junit.Test;
public class TestImplicitSplitOnTuple {
@Test
public void testImplicitSplitterOnTuple() throws Exception {
PigServer pigServer = new PigServer(Util.getLocalTestMode());
Data data = Storage.resetData(pigServer);
data.set("input",
tuple("1", "1001", "101"),
tuple("1", "1002", "103"),
tuple("1", "1003", "102"),
tuple("1", "1004", "102"),
tuple("2", "1005", "101"),
tuple("2", "1003", "101"),
tuple("2", "1002", "123"),
tuple("3", "1042", "101"),
tuple("3", "1005", "101"),
tuple("3", "1002", "133"));
pigServer.registerQuery(
"inp = LOAD 'input' USING mock.Storage() AS (memberId:long, shopId:long, score:int);"+
"tuplified = FOREACH inp GENERATE (memberId, shopId) AS tuplify, score;"+
"D1 = FOREACH tuplified GENERATE tuplify.memberId as memberId, tuplify.shopId as shopId, score AS score;"+
"D2 = FOREACH tuplified GENERATE tuplify.memberId as memberId, tuplify.shopId as shopId, score AS score;"+
"J = JOIN D1 By shopId, D2 by shopId;"+
"K = FOREACH J GENERATE D1::memberId AS member_id1, D2::memberId AS member_id2, D1::shopId as shop;"+
"L = ORDER K by shop, member_id1, member_id2;"+
"STORE L into 'output' using mock.Storage;");
List<Tuple> list = data.get("output");
assertEquals("list: "+list, 20, list.size());
assertEquals("(1,1,1001)", list.get(0).toString());
assertEquals("(1,1,1002)", list.get(1).toString());
assertEquals("(1,2,1002)", list.get(2).toString());
assertEquals("(1,3,1002)", list.get(3).toString());
assertEquals("(2,1,1002)", list.get(4).toString());
assertEquals("(2,2,1002)", list.get(5).toString());
assertEquals("(2,3,1002)", list.get(6).toString());
assertEquals("(3,1,1002)", list.get(7).toString());
assertEquals("(3,2,1002)", list.get(8).toString());
assertEquals("(3,3,1002)", list.get(9).toString());
assertEquals("(1,1,1003)", list.get(10).toString());
assertEquals("(1,2,1003)", list.get(11).toString());
assertEquals("(2,1,1003)", list.get(12).toString());
assertEquals("(2,2,1003)", list.get(13).toString());
assertEquals("(1,1,1004)", list.get(14).toString());
assertEquals("(2,2,1005)", list.get(15).toString());
assertEquals("(2,3,1005)", list.get(16).toString());
assertEquals("(3,2,1005)", list.get(17).toString());
assertEquals("(3,3,1005)", list.get(18).toString());
assertEquals("(3,3,1042)", list.get(19).toString());
}
}