Project

General

Profile

1 2134 costa
/**
2
 *  '$RCSfile$'
3
 *  Copyright: 2004 Regents of the University of California and the
4
 *              National Center for Ecological Analysis and Synthesis,
5
 *              and the University of New Mexico
6
 *
7
 *  Purpose: To test the Harvester class by using JUnit
8
 *
9
 *   '$Author$'
10
 *     '$Date$'
11
 * '$Revision$'
12
 *
13
 * This program is free software; you can redistribute it and/or modify
14
 * it under the terms of the GNU General Public License as published by
15
 * the Free Software Foundation; either version 2 of the License, or
16
 * (at your option) any later version.
17
 *
18
 * This program is distributed in the hope that it will be useful,
19
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21
 * GNU General Public License for more details.
22
 *
23
 * You should have received a copy of the GNU General Public License
24
 * along with this program; if not, write to the Free Software
25
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
26
 */
27
28
package edu.ucsb.nceas.metacattest.harvesterClient;
29
30
import edu.ucsb.nceas.metacat.harvesterClient.Harvester;
31 2158 costa
import edu.ucsb.nceas.utilities.Options;
32 2134 costa
import java.io.File;
33
import java.io.FileInputStream;
34
import java.io.IOException;
35
import junit.framework.Test;
36
import junit.framework.TestCase;
37
import junit.framework.TestSuite;
38
39
/**
40 2255 costa
 * Tests Harvester code using JUnit.
41 2134 costa
 *
42
 * @author  costa
43
 */
44
public class HarvesterTest extends TestCase {
45
46
  private Harvester harvester;
47
48
49 2255 costa
  /**
50
   * Constructor for this test.
51
   *
52
   * @param name     name of the test case
53
   */
54 2134 costa
  public HarvesterTest(String name) {
55
    super(name);
56
  }
57
58 2255 costa
59
  /**
60
   * Sets up the test by instantiating a Harvester object.
61
   */
62 2134 costa
  protected void setUp() {
63
    harvester = new Harvester();
64
  }
65
66 2255 costa
67
  /**
68
   * No clean-up actions necessary for these tests.
69
   */
70 2134 costa
  protected void tearDown() {
71
  }
72
73 2255 costa
74
  /**
75
   * Tests the dequoteText() string function. It converts single quotes to
76
   * double quotes.
77
   */
78 2143 costa
  public void testDequoteText() {
79
    String singleQuoteString = "I can't see how it's done!\n";
80
    String compareString = "I can\"t see how it\"s done!";
81
    String dequotedString = "";
82
83
    dequotedString = harvester.dequoteText(singleQuoteString);
84
    assertTrue(dequotedString.equals(compareString));
85
    System.out.println("Dequoted string: " + dequotedString);
86
  }
87
88
89 2134 costa
  /**
90 2255 costa
   * Tests that the Harvester object was created successfully.
91 2143 costa
   */
92
  public void testHarvesterObject() {
93
    assertTrue(harvester != null);
94
  }
95
96
97
  /**
98 2134 costa
   * Tests loading of Harvester properties from a configuration file.
99
   */
100 2158 costa
  public void testLoadOptions() {
101
    Options options;
102
    String ctm;
103
    boolean test = true;
104
105
    Harvester.loadOptions(test);
106
    options = Harvester.options;
107
    ctm = options.getOption("connectToMetacat");
108
    assertTrue(ctm.equals("true") || ctm.equals("false"));
109 2134 costa
  }
110
111
112
  /**
113 2143 costa
   * Prints the files in the current working directory. This may be useful
114
   * for determining which directory all other tests are running in.
115
   */
116
  public void testWorkingDirectory() {
117
    String[] dir = new java.io.File(".").list(); // Get files in current dir
118
119
    java.util.Arrays.sort(dir);                  // Sort the directory listing
120
121
    for (int i=0; i<dir.length; i++)
122
      System.out.println(dir[i]);                // Print the list
123
  }
124
125
126
  /**
127 2134 costa
   * Returns the test suite. The test suite consists of all methods in this
128
   * class whose names start with "test".
129
   *
130
   * @return  a TestSuite object
131
   */
132
  public static Test suite() {
133
    return new TestSuite(HarvesterTest.class);
134
  }
135
136
137
  /**
138
   * The main program. Runs the test suite.
139
   *
140
   * @param args   command line argument array.
141
   */
142
  public static void main(String args[]) {
143
    junit.textui.TestRunner.run(suite());
144
  }
145
146
}