test_graphalignedsegment.cpp 2.97 KB
/*
 * ASCLITE
 * Author: Jerome Ajot, Jon Fiscus, Nicolas Radde, Chris Laprun
 *
 * This software was developed at the National Institute of Standards and Technology by 
 * employees of the Federal Government in the course of their official duties. Pursuant
 * to title 17 Section 105 of the United States Code this software is not subject to
 * copyright protection and is in the public domain. ASCLITE is an experimental system.
 * NIST assumes no responsibility whatsoever for its use by other parties, and makes no
 * guarantees, expressed or implied, about its quality, reliability, or any other
 * characteristic. We would appreciate acknowledgement if the software is used.
 *
 * THIS SOFTWARE IS PROVIDED "AS IS."  With regard to this software, NIST MAKES NO EXPRESS
 * OR IMPLIED WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING MERCHANTABILITY,
 * OR FITNESS FOR A PARTICULAR PURPOSE.
 */

#include "test_graphalignedsegment.h" // class's header file
#include "speech.h"
#include "segment.h"

// class constructor
GraphAlignedSegmentTest::GraphAlignedSegmentTest()
{
	// insert your code here
}

// class destructor
GraphAlignedSegmentTest::~GraphAlignedSegmentTest()
{
	// insert your code here
}

/*
 * Launch all the tests on GraphAlignedSegmentTest
 */
void GraphAlignedSegmentTest::testAll()
{
	cout << "- test Operator(==) " << endl;
  testEqualOperator();
}

/*
 * Test the Equal operator behavior.
 */
void GraphAlignedSegmentTest::testEqualOperator()
{
  SpeechSet* speechSet = new SpeechSet();
	Speech* speech = new Speech(speechSet);
	Segment* segment = Segment::CreateWithEndTime(0, 10000, speech);
	Token* t1 = Token::CreateWithEndTime(4000, 10000, segment, "first");
  Token* t2 = Token::CreateWithEndTime(4000, 10000, segment, "first");
  Token* t3 = Token::CreateWithEndTime(4000, 10000, segment, "second");
  Token* t4 = Token::CreateWithEndTime(4000, 10000, segment, "bis");
	GraphAlignedToken* gat1 = new GraphAlignedToken(2);
	GraphAlignedToken* gat2 = new GraphAlignedToken(2);
	GraphAlignedToken* gat3 = new GraphAlignedToken(2);
  GraphAlignedToken* gat4 = new GraphAlignedToken(2);
  gat1->SetToken(0, t1);
  gat1->SetToken(1, t3);
  gat2->SetToken(0, t1);
  gat2->SetToken(1, t3);
  gat3->SetToken(0, t2);
  gat3->SetToken(1, t3);
  gat4->SetToken(0, t1);
  gat4->SetToken(1, t4);
  GraphAlignedSegment* gas1 = new GraphAlignedSegment(1);
  GraphAlignedSegment* gas2 = new GraphAlignedSegment(1);
  GraphAlignedSegment* gas3 = new GraphAlignedSegment(1);
  GraphAlignedSegment* gas4 = new GraphAlignedSegment(0);
  gas1->AddFrontGraphAlignedToken(gat1);
  gas1->AddFrontGraphAlignedToken(gat4);
  gas2->AddFrontGraphAlignedToken(gat1);
  gas2->AddFrontGraphAlignedToken(gat4);
  gas3->AddFrontGraphAlignedToken(gat2);
  gas3->AddFrontGraphAlignedToken(gat4);
  gas4->AddFrontGraphAlignedToken(gat1);
  gas4->AddFrontGraphAlignedToken(gat3);
  assert(*gas1 == *gas2);
  assert(*gas1 == *gas3);
  assert(!(*gas1 == *gas4));
	/*
	delete gas1;
	delete gas2;
	delete gas3;
	delete gas4;
	*/
	delete speechSet;
}