1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski using System;
25*b1cdbd2cSJim Jagielski using System.Reflection;
26*b1cdbd2cSJim Jagielski using System.IO;
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski // __________  implementation  ____________________________________
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski /** Create and modify a spreadsheet document.
31*b1cdbd2cSJim Jagielski  */
32*b1cdbd2cSJim Jagielski namespace cliversion
33*b1cdbd2cSJim Jagielski {
34*b1cdbd2cSJim Jagielski public class RunTests
35*b1cdbd2cSJim Jagielski {
36*b1cdbd2cSJim Jagielski 
Main(String[] args)37*b1cdbd2cSJim Jagielski     public static int Main(String[] args)
38*b1cdbd2cSJim Jagielski     {
39*b1cdbd2cSJim Jagielski //        System.Diagnostics.Debugger.Launch();
40*b1cdbd2cSJim Jagielski         //get the path to the directory
41*b1cdbd2cSJim Jagielski         string sLocation = Assembly.GetExecutingAssembly().Location;
42*b1cdbd2cSJim Jagielski         sLocation = sLocation.Substring(0, sLocation.LastIndexOf('\\'));
43*b1cdbd2cSJim Jagielski         // Create a reference to the current directory.
44*b1cdbd2cSJim Jagielski         DirectoryInfo di = new DirectoryInfo(sLocation);
45*b1cdbd2cSJim Jagielski         // Create an array representing the files in the current directory.
46*b1cdbd2cSJim Jagielski         FileInfo[] fi = di.GetFiles();
47*b1cdbd2cSJim Jagielski 
48*b1cdbd2cSJim Jagielski         //For every found dll try to figure out if it contains a
49*b1cdbd2cSJim Jagielski         //cliversion.Version class
50*b1cdbd2cSJim Jagielski 		foreach (FileInfo fiTemp in fi)
51*b1cdbd2cSJim Jagielski 		{
52*b1cdbd2cSJim Jagielski 			if (fiTemp.Extension != ".dll"
53*b1cdbd2cSJim Jagielski                 || ! fiTemp.Name.StartsWith("version"))
54*b1cdbd2cSJim Jagielski 				continue;
55*b1cdbd2cSJim Jagielski 
56*b1cdbd2cSJim Jagielski             Assembly ass = null;
57*b1cdbd2cSJim Jagielski             Object objVersion = null;
58*b1cdbd2cSJim Jagielski 			try
59*b1cdbd2cSJim Jagielski 			{
60*b1cdbd2cSJim Jagielski                 string sName = fiTemp.Name.Substring(0, fiTemp.Name.LastIndexOf(".dll"));
61*b1cdbd2cSJim Jagielski 				ass = Assembly.Load(sName);
62*b1cdbd2cSJim Jagielski 			}
63*b1cdbd2cSJim Jagielski 			catch (BadImageFormatException)
64*b1cdbd2cSJim Jagielski 			{
65*b1cdbd2cSJim Jagielski 				continue;
66*b1cdbd2cSJim Jagielski 			}
67*b1cdbd2cSJim Jagielski 			catch (Exception e)
68*b1cdbd2cSJim Jagielski 			{
69*b1cdbd2cSJim Jagielski 				Console.WriteLine("#Unexpected Exception");
70*b1cdbd2cSJim Jagielski 				Console.WriteLine(e.Message);
71*b1cdbd2cSJim Jagielski                 return -1;
72*b1cdbd2cSJim Jagielski 			}
73*b1cdbd2cSJim Jagielski 
74*b1cdbd2cSJim Jagielski             //Assembly is loaded, instantiate cliversion.Version
75*b1cdbd2cSJim Jagielski 			try
76*b1cdbd2cSJim Jagielski 			{
77*b1cdbd2cSJim Jagielski 				//This runs the test
78*b1cdbd2cSJim Jagielski 				objVersion = ass.CreateInstance("cliversion.Version");
79*b1cdbd2cSJim Jagielski 				if (objVersion == null)
80*b1cdbd2cSJim Jagielski 					continue;
81*b1cdbd2cSJim Jagielski 				Console.WriteLine("#Tested successfully " + fiTemp.Name);
82*b1cdbd2cSJim Jagielski 				//Starting the office the second time may fail without this pause
83*b1cdbd2cSJim Jagielski 				System.Threading.Thread.Sleep(2000);
84*b1cdbd2cSJim Jagielski 			}
85*b1cdbd2cSJim Jagielski 			catch (Exception e)
86*b1cdbd2cSJim Jagielski 			{
87*b1cdbd2cSJim Jagielski 				TargetInvocationException te = e as TargetInvocationException;
88*b1cdbd2cSJim Jagielski 				if (te != null)
89*b1cdbd2cSJim Jagielski 				{
90*b1cdbd2cSJim Jagielski 					FileNotFoundException fe = e.InnerException as FileNotFoundException;
91*b1cdbd2cSJim Jagielski 					if (fe != null)
92*b1cdbd2cSJim Jagielski 					{
93*b1cdbd2cSJim Jagielski 						Console.WriteLine(fiTemp.Name + " did not find " + fe.FileName +
94*b1cdbd2cSJim Jagielski 							". Maybe the " + fe.FileName + " is not installed or does not match the referenced version."  +
95*b1cdbd2cSJim Jagielski 							"Original message: " + fe.Message + "\n\n FusionLog: \n" + fe.FusionLog );
96*b1cdbd2cSJim Jagielski 						return -1;
97*b1cdbd2cSJim Jagielski 					}
98*b1cdbd2cSJim Jagielski 					FileLoadException fl = e.InnerException as FileLoadException;
99*b1cdbd2cSJim Jagielski 					if (fl != null)
100*b1cdbd2cSJim Jagielski 					{
101*b1cdbd2cSJim Jagielski 						Console.WriteLine(fiTemp.Name + " could not load " + fl.FileName +
102*b1cdbd2cSJim Jagielski 							". Maybe the version of " + fl.FileName + " does not match the referenced version. " +
103*b1cdbd2cSJim Jagielski 							"Original message: " + fl.Message + "\n\n FusionLog: \n" + fl.FusionLog );
104*b1cdbd2cSJim Jagielski 						return -1;
105*b1cdbd2cSJim Jagielski 					}
106*b1cdbd2cSJim Jagielski 
107*b1cdbd2cSJim Jagielski                     if (e.InnerException != null)
108*b1cdbd2cSJim Jagielski                     {
109*b1cdbd2cSJim Jagielski                         Console.WriteLine(e.InnerException);
110*b1cdbd2cSJim Jagielski                     }
111*b1cdbd2cSJim Jagielski 				}
112*b1cdbd2cSJim Jagielski 				Console.WriteLine("#Unexpected Exception");
113*b1cdbd2cSJim Jagielski 				Console.WriteLine(e.Message);
114*b1cdbd2cSJim Jagielski 				return -1;
115*b1cdbd2cSJim Jagielski 			}
116*b1cdbd2cSJim Jagielski 		}
117*b1cdbd2cSJim Jagielski         //For some unknown reason this program hangs sometimes when started from java. This is
118*b1cdbd2cSJim Jagielski         //a workaround that makes the problem disappear.
119*b1cdbd2cSJim Jagielski         System.Threading.Thread.Sleep(1000);
120*b1cdbd2cSJim Jagielski         return 0;
121*b1cdbd2cSJim Jagielski     }
122*b1cdbd2cSJim Jagielski }
123*b1cdbd2cSJim Jagielski }
124