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