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 package fvt.gui.sc.validity;
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski import static org.junit.Assert.*;
25*b1cdbd2cSJim Jagielski import static testlib.gui.AppTool.*;
26*b1cdbd2cSJim Jagielski import static testlib.gui.UIMap.*;
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski import org.junit.After;
29*b1cdbd2cSJim Jagielski import org.junit.Before;
30*b1cdbd2cSJim Jagielski import org.junit.Rule;
31*b1cdbd2cSJim Jagielski import org.junit.Test;
32*b1cdbd2cSJim Jagielski import org.openoffice.test.common.Logger;
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski import testlib.gui.AppTool;
35*b1cdbd2cSJim Jagielski import testlib.gui.SCTool;
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski public class ValidityDateSupport1024Columns {
38*b1cdbd2cSJim Jagielski 
39*b1cdbd2cSJim Jagielski 	@Rule
40*b1cdbd2cSJim Jagielski 	public Logger log = Logger.getLogger(this);
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski 	@Before
setUp()43*b1cdbd2cSJim Jagielski 	public void setUp() throws Exception {
44*b1cdbd2cSJim Jagielski 		app.start(true);
45*b1cdbd2cSJim Jagielski 		AppTool.newSpreadsheet();
46*b1cdbd2cSJim Jagielski 	}
47*b1cdbd2cSJim Jagielski 
48*b1cdbd2cSJim Jagielski 	@After
tearDown()49*b1cdbd2cSJim Jagielski 	public void tearDown() throws Exception {
50*b1cdbd2cSJim Jagielski 		app.stop();
51*b1cdbd2cSJim Jagielski 	}
52*b1cdbd2cSJim Jagielski 
53*b1cdbd2cSJim Jagielski 	/**
54*b1cdbd2cSJim Jagielski 	 * test Allow Greater than or equal to Date type in Validity, support 1024
55*b1cdbd2cSJim Jagielski 	 * columns.
56*b1cdbd2cSJim Jagielski 	 */
57*b1cdbd2cSJim Jagielski 	@Test
testValidityDateSupport1024Columns()58*b1cdbd2cSJim Jagielski 	public void testValidityDateSupport1024Columns() {
59*b1cdbd2cSJim Jagielski 		SCTool.selectRange("ALM1000:ALO1005");
60*b1cdbd2cSJim Jagielski 		app.dispatch(".uno:Validation");
61*b1cdbd2cSJim Jagielski 
62*b1cdbd2cSJim Jagielski 		scValidityCriteriaTabpage.select();
63*b1cdbd2cSJim Jagielski 		scValidityCriteriaAllowList.select(3); // "Date"
64*b1cdbd2cSJim Jagielski 		scValidityDecimalCompareOperator.select(2); // "greater than"
65*b1cdbd2cSJim Jagielski 		scValiditySourceInput.setText("01/01/08");
66*b1cdbd2cSJim Jagielski 		scValidityErrorAlertTabPage.select();
67*b1cdbd2cSJim Jagielski 		scValidityShowErrorMessage.check();
68*b1cdbd2cSJim Jagielski 		scValidityErrorMessageTitle.setText("Stop to enter");
69*b1cdbd2cSJim Jagielski 		scValidityErrorMessage.setText("Invalid value");
70*b1cdbd2cSJim Jagielski 		scValidityErrorAlertTabPage.ok();
71*b1cdbd2cSJim Jagielski 
72*b1cdbd2cSJim Jagielski 		SCTool.selectRange("ALM1001");
73*b1cdbd2cSJim Jagielski 		scInputBarInput.activate();
74*b1cdbd2cSJim Jagielski 		typeKeys("02/01/08<enter>");
75*b1cdbd2cSJim Jagielski 		assertEquals("Cell text in ALM1001 is not 02/01/08","02/01/08", SCTool.getCellText("ALM1001"));
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski 		SCTool.selectRange("ALM1002");
78*b1cdbd2cSJim Jagielski 		scInputBarInput.activate();
79*b1cdbd2cSJim Jagielski 		typeKeys("01/02/08<enter>");
80*b1cdbd2cSJim Jagielski 		assertEquals("Cell text in ALM1002 is not 01/02/08","01/02/08", SCTool.getCellText("ALM1002"));
81*b1cdbd2cSJim Jagielski 
82*b1cdbd2cSJim Jagielski 		SCTool.selectRange("ALM1003");
83*b1cdbd2cSJim Jagielski 		scInputBarInput.activate();
84*b1cdbd2cSJim Jagielski 		typeKeys("01/01/08<enter>");
85*b1cdbd2cSJim Jagielski 		assertEquals("Have no alert message","Invalid value", activeMsgBox.getMessage());
86*b1cdbd2cSJim Jagielski 		activeMsgBox.ok();
87*b1cdbd2cSJim Jagielski 		assertEquals("Validity have not filter invalid value","", SCTool.getCellText("ALM1003"));
88*b1cdbd2cSJim Jagielski 
89*b1cdbd2cSJim Jagielski 		SCTool.selectRange("AML1003");
90*b1cdbd2cSJim Jagielski 		scInputBarInput.activate();
91*b1cdbd2cSJim Jagielski 		typeKeys("12/31/07<enter>");
92*b1cdbd2cSJim Jagielski 		assertEquals("Have no alert message","Invalid value", activeMsgBox.getMessage());
93*b1cdbd2cSJim Jagielski 		activeMsgBox.ok();
94*b1cdbd2cSJim Jagielski 		assertEquals("Validity have not filter invalid value","", SCTool.getCellText("AML1003"));
95*b1cdbd2cSJim Jagielski 	}
96*b1cdbd2cSJim Jagielski }
97