update dev300-m57
[ooovba.git] / testtools / source / cliversioning / readme.txt
blobeafe05e866c57c5c711297815eb29c740d50cc68
1 #*************************************************************************
2
3 #  DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 #  
5 #  Copyright 2008 by Sun Microsystems, Inc.
6
7 #  OpenOffice.org - a multi-platform office productivity suite
8
9 #  $RCSfile: readme.txt,v $
10 #  $Revision: 1.2 $
11
12 #  This file is part of OpenOffice.org.
13
14 #  OpenOffice.org is free software: you can redistribute it and/or modify
15 #  it under the terms of the GNU Lesser General Public License version 3
16 #  only, as published by the Free Software Foundation.
17
18 #  OpenOffice.org 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 Lesser General Public License version 3 for more details
22 #  (a copy is included in the LICENSE file that accompanied this code).
23
24 #  You should have received a copy of the GNU Lesser General Public License
25 #  version 3 along with OpenOffice.org.  If not, see
26 #  <http://www.openoffice.org/license.html>
27 #  for a copy of the LGPLv3 License.
28
29 # ************************************************************************/
34 WINDOWS ONLY, no other platforms
39 This test checks if the cli assemblies and their policy files are installed in the 
40 GAC and if the policy files are correct. The office must be installed with complete 
41 system integration. That is, one does not use setup /a for starting the 
42 installation.
44 In OOo 3.0 there was a breanking change so that the test created for previous 
45 version do not work anymore. To use these old tests one needs to install a 
46 version of OOo less than v 3.0. Then one needs to check out the cli_ure module 
47 for that version. The tests are contained in cli_ure/qa/versioning.
49 In the sub directory version_libs are libraries which are linked with (referencing)
50 cli_cppuhelper
51 cli_basetypes
52 cli_ure
53 cli_uretypes
54 cli_oootypes
56 They are named version_3_0_0 etc, where the name indicates the version of the 
57 office for which they were initially build. If there are only the assemblies 
58 for example OOo2.0.2 installed and a client was build with the assemblies from 
59 OOo2 then the policy assemblies must make the correct redirection. 
61 When calling dmake then the executable runtest.exe and version_current.dll are 
62 build. When runtest runs then it loads all dlls, which names start with 
63 "version", from the same directory and tries to run a particular test code 
64 which is only available in the version_xxx.dll s. The code in the 
65 version_xxx.dlls uses the cli default bootstrap mechanism to find the office 
66 installation and start the office. When running runtest in a build environment 
67 then it may use the wrong libraries for bootstrapping in which case the test 
68 fails. Then one has to set PATH which must point to the program directory of 
69 the office installation. For example:
71 set PATH=d:\office\program
73 runtest stops when a test failed to run. It writes error information to the 
74 console which shows which version_xxx.dll failed to run and if this was due to 
75 a referenced assembly that could not be loaded. This would be the case if such 
76 an assembly or the policy assembly is not properly installed or the redirection 
77 in the policy assembly is wrong. 
79 The version_current.dll references the assemblies in the current build 
80 environment. version_current.dll is also executed when runtest is started.
82 To run the whole test one can either
83 1. start testools/wntmsci11.pro/bin/runtests.exe in a console where no 
84 environment is set.
85 2. Call dmake run in testools/qa/cliversions
87 For a limited test one can call in this directory
88 dmake run office=d:\office
89 There must not be an office installed in the system (the assemblies from the GAC 
90 would then be used). Only the test with the version_current.dll will succeed
91 because there are no policy files installed. This test requires that all 
92 assemblies are copied next to runtests.exe - the makefile will do that.
94 The parameter office must be a system path to the office installation 
95 directory. The java code calls runtest and also sets PATH so that the test 
96 works in the build environment. It also sets UNO_PATH so that the office will be
97 found. If the test says that it failed, then one should run runtest directly 
98 because it puts out more information.
102 Creating a new version_xxx.dll
103 ==============================
104 When a version of our assemblies changes then one should provide a new version dll which test exactly the assemblies with the changed version. This is easily done:
105 1. set the build environment in which the new versions are effectiv.
106 2  call: dmake name=version_xxx.dll
107 3. copy the new version dll from the output tree into qa/versioning/version_libs
108 4. commit the new version.dll using the -kb switch (only when creating the new file : cvs new -kb version_3_1_0.dll)