forked from amazingfate/loongoffice
Revert changes making HSQLDB related unit tests test Firebird migration. They should still test the HSQLDB driver. It reverts part of 159dd28651788a19848eae56693ad06ed947414d Change-Id: If2b9207e95055418bd1dc1dc6e472335de311d1e Reviewed-on: https://gerrit.libreoffice.org/52873 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Tamás Bunth <btomi96@gmail.com>
160 lines
5.8 KiB
Java
160 lines
5.8 KiB
Java
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* This file incorporates work covered by the following license notice:
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
* with this work for additional information regarding copyright
|
|
* ownership. The ASF licenses this file to you under the Apache
|
|
* License, Version 2.0 (the "License"); you may not use this file
|
|
* except in compliance with the License. You may obtain a copy of
|
|
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
|
*/
|
|
package complex.dbaccess;
|
|
|
|
import com.sun.star.beans.PropertyValue;
|
|
import com.sun.star.container.XNameAccess;
|
|
import com.sun.star.frame.FrameSearchFlag;
|
|
import com.sun.star.frame.XComponentLoader;
|
|
import com.sun.star.frame.XModel;
|
|
import com.sun.star.frame.XStorable;
|
|
import com.sun.star.lang.XComponent;
|
|
import com.sun.star.sdb.XOfficeDatabaseDocument;
|
|
import com.sun.star.sdb.application.XDatabaseDocumentUI;
|
|
import com.sun.star.sdbcx.XTablesSupplier;
|
|
import com.sun.star.uno.Exception;
|
|
import com.sun.star.uno.UnoRuntime;
|
|
import connectivity.tools.HsqlColumnDescriptor;
|
|
import connectivity.tools.HsqlDatabase;
|
|
import connectivity.tools.HsqlTableDescriptor;
|
|
import java.io.IOException;
|
|
|
|
|
|
// ---------- junit imports -----------------
|
|
import org.junit.After;
|
|
import org.junit.Before;
|
|
import org.junit.Test;
|
|
import static org.junit.Assert.*;
|
|
|
|
|
|
/** complex test case for Base's application UI
|
|
*/
|
|
public class ApplicationController extends TestCase
|
|
{
|
|
|
|
private HsqlDatabase m_database;
|
|
private XOfficeDatabaseDocument m_databaseDocument;
|
|
private XDatabaseDocumentUI m_documentUI;
|
|
|
|
public String getTestObjectName()
|
|
{
|
|
return getClass().getName();
|
|
}
|
|
|
|
|
|
private void impl_closeDocument()
|
|
{
|
|
if (m_database != null)
|
|
{
|
|
m_database.close();
|
|
m_database = null;
|
|
m_databaseDocument = null;
|
|
m_documentUI = null;
|
|
}
|
|
}
|
|
|
|
|
|
private void impl_switchToDocument(String _documentURL) throws java.lang.Exception
|
|
{
|
|
// close previous database document
|
|
impl_closeDocument();
|
|
|
|
// create/load the new database document
|
|
m_database = (_documentURL == null)
|
|
? new HsqlDatabase(getMSF())
|
|
: new HsqlDatabase(getMSF(), _documentURL);
|
|
m_databaseDocument = m_database.getDatabaseDocument();
|
|
|
|
// load it into a frame
|
|
final Object object = getMSF().createInstance("com.sun.star.frame.Desktop");
|
|
final XComponentLoader xComponentLoader = UnoRuntime.queryInterface(XComponentLoader.class, object);
|
|
final XComponent loadedComponent = xComponentLoader.loadComponentFromURL(m_database.getDocumentURL(), "_blank", FrameSearchFlag.ALL, new PropertyValue[0]);
|
|
|
|
assertTrue("too many document instances!",
|
|
UnoRuntime.areSame(loadedComponent, m_databaseDocument));
|
|
|
|
// get the controller, which provides access to various UI operations
|
|
final XModel docModel = UnoRuntime.queryInterface(XModel.class,
|
|
loadedComponent);
|
|
m_documentUI = UnoRuntime.queryInterface(XDatabaseDocumentUI.class,
|
|
docModel.getCurrentController());
|
|
}
|
|
|
|
|
|
@Before
|
|
@Override
|
|
public void before() throws java.lang.Exception
|
|
{
|
|
super.before();
|
|
impl_switchToDocument(null);
|
|
}
|
|
|
|
|
|
@After
|
|
@Override
|
|
public void after() throws java.lang.Exception
|
|
{
|
|
impl_closeDocument();
|
|
super.after();
|
|
}
|
|
|
|
|
|
@Test
|
|
public void checkSaveAs() throws Exception, IOException, java.lang.Exception
|
|
{
|
|
// issue 93737 describes the problem that when you save-as a database document, and do changes to it,
|
|
// then those changes are saved in the old document, actually
|
|
final String oldDocumentURL = m_database.getDocumentURL();
|
|
|
|
final String newDocumentURL = createTempFileURL();
|
|
|
|
// store the doc in a new location
|
|
final XStorable storeDoc = UnoRuntime.queryInterface( XStorable.class, m_databaseDocument );
|
|
storeDoc.storeAsURL( newDocumentURL, new PropertyValue[] { } );
|
|
|
|
// connect
|
|
m_documentUI.connect();
|
|
assertTrue("could not connect to " + m_database.getDocumentURL(), m_documentUI.isConnected());
|
|
|
|
// create a table in the database
|
|
m_database.createTable(new HsqlTableDescriptor("abc", new HsqlColumnDescriptor[]
|
|
{
|
|
new HsqlColumnDescriptor("a", "VARCHAR(50)"),
|
|
new HsqlColumnDescriptor("b", "VARCHAR(50)"),
|
|
new HsqlColumnDescriptor("c", "VARCHAR(50)")
|
|
}));
|
|
|
|
// load the old document, and verify there is *no* table therein
|
|
impl_switchToDocument(oldDocumentURL);
|
|
m_documentUI.connect();
|
|
assertTrue("could not connect to " + m_database.getDocumentURL(), m_documentUI.isConnected());
|
|
XTablesSupplier suppTables = UnoRuntime.queryInterface( XTablesSupplier.class, m_documentUI.getActiveConnection() );
|
|
XNameAccess tables = suppTables.getTables();
|
|
assertTrue("the table was created in the wrong database", !tables.hasByName("abc"));
|
|
|
|
// load the new document, and verify there *is* a table therein
|
|
impl_switchToDocument(newDocumentURL);
|
|
m_documentUI.connect();
|
|
assertTrue("could not connect to " + m_database.getDocumentURL(), m_documentUI.isConnected());
|
|
|
|
suppTables = UnoRuntime.queryInterface( XTablesSupplier.class, m_documentUI.getActiveConnection() );
|
|
tables = suppTables.getTables();
|
|
assertTrue("the newly created table has not been written", tables.hasByName("abc"));
|
|
}
|
|
}
|