Package com.cloudera.cdk.morphline.twitter

Source Code of com.cloudera.cdk.morphline.twitter.ReadJsonTweetsTest

/*
* Copyright 2013 Cloudera Inc.
*
* 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.cloudera.cdk.morphline.twitter;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.util.Arrays;
import java.util.Iterator;

import java.util.TimeZone;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

import com.cloudera.cdk.morphline.api.AbstractMorphlineTest;
import com.cloudera.cdk.morphline.api.Record;
import com.cloudera.cdk.morphline.base.Fields;

public class ReadJsonTweetsTest extends AbstractMorphlineTest {

  private TimeZone defaultTimeZone = TimeZone.getDefault();

  @Before
  public void setUp() throws Exception {
    // Test is hardcoded to assume US Pacific timezone, so change the VM timezone for the
    // duration of the test
    TimeZone.setDefault(TimeZone.getTimeZone("US/Pacific"));
    super.setUp();
  }

  @After
  public void tearDown() throws Exception {
    super.tearDown();
    TimeZone.setDefault(defaultTimeZone);
  }

  @Test
  public void testReadJsonTweets() throws Exception {
    morphline = createMorphline("test-morphlines/readJsonTweets");   
    Record record = new Record();
    record.put(Fields.ATTACHMENT_BODY, getInputStream("non-length-delimited-20130430-234145-tweets.json.gz"));
    record.put(Fields.ATTACHMENT_NAME, "non-length-delimited-20130430-234145-tweets.json.gz");
    startSession();
    assertTrue(morphline.process(record));
    assertEquals(1, collector.getNumStartEvents());
    Iterator<Record> iter = collector.getRecords().iterator();
    assertEquals(Arrays.asList("1985-09-04T18:01:01Z"), iter.next().get("created_at"));
    assertEquals(Arrays.asList("1985-09-04T19:14:34Z"), iter.next().get("created_at"));
    assertFalse(iter.hasNext());
  }
   
  @Test
  public void testReadJsonTweetsLengthDelimited() throws Exception {
    morphline = createMorphline("test-morphlines/readJsonTweetsLengthDelimited");   
    Record record = new Record();   
    record.put(Fields.ATTACHMENT_BODY, getInputStream("sample-statuses-20120906-141433"));
    startSession();
    assertTrue(morphline.process(record));
    assertEquals(1, collector.getNumStartEvents());
    Iterator<Record> iter = collector.getRecords().iterator();
    assertEquals(Arrays.asList("1985-09-04T18:01:01Z"), iter.next().get("created_at"));
    assertEquals(Arrays.asList("1985-09-04T19:14:34Z"), iter.next().get("created_at"));
    assertFalse(iter.hasNext());
  }
 
  private InputStream getInputStream(String file) throws FileNotFoundException {
    return new FileInputStream(new File(RESOURCES_DIR + "/test-documents/" + file));
  }
   
}
TOP

Related Classes of com.cloudera.cdk.morphline.twitter.ReadJsonTweetsTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.