/*
* Copyright 2010-2012 Luca Garulli (l.garulli--at--orientechnologies.com)
*
* Licensed 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
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.orientechnologies.orient.test.database.auto;
import org.testng.Assert;
import org.testng.annotations.*;
import com.orientechnologies.orient.core.db.document.ODatabaseDocumentTx;
import com.orientechnologies.orient.core.index.OIndex;
import com.orientechnologies.orient.core.metadata.schema.OClass;
import com.orientechnologies.orient.core.metadata.schema.OSchema;
import com.orientechnologies.orient.core.metadata.schema.OType;
import com.orientechnologies.orient.core.sql.OCommandSQL;
@Test(groups = { "index" })
public class SQLDropIndexTest {
private ODatabaseDocumentTx database;
private static final OType EXPECTED_PROP1_TYPE = OType.DOUBLE;
private static final OType EXPECTED_PROP2_TYPE = OType.INTEGER;
private final String url;
@Parameters(value = "url")
public SQLDropIndexTest(@Optional final String url) {
this.url = BaseTest.prepareUrl(url);
}
@BeforeClass
public void beforeClass() {
database = new ODatabaseDocumentTx(url);
if (database.isClosed())
database.open("admin", "admin");
final OSchema schema = database.getMetadata().getSchema();
final OClass oClass = schema.createClass("SQLDropIndexTestClass");
oClass.createProperty("prop1", EXPECTED_PROP1_TYPE);
oClass.createProperty("prop2", EXPECTED_PROP2_TYPE);
schema.save();
}
@AfterClass
public void afterClass() throws Exception {
if (database.isClosed())
database.open("admin", "admin");
database.command(new OCommandSQL("delete from SQLDropIndexTestClass")).execute();
database.command(new OCommandSQL("drop class SQLDropIndexTestClass")).execute();
database.reload();
database.close();
}
@BeforeMethod
public void beforeMethod() {
if (database.isClosed())
database.open("admin", "admin");
}
@AfterMethod
public void afterMethod() {
database.close();
}
@Test
public void testOldSyntax() throws Exception {
database.command(new OCommandSQL("CREATE INDEX SQLDropIndexTestClass.prop1 UNIQUE")).execute();
database.getMetadata().getIndexManager().reload();
OIndex<?> index = database.getMetadata().getSchema().getClass("SQLDropIndexTestClass")
.getClassIndex("SQLDropIndexTestClass.prop1");
Assert.assertNotNull(index);
database.command(new OCommandSQL("DROP INDEX SQLDropIndexTestClass.prop1")).execute();
database.getMetadata().getIndexManager().reload();
index = database.getMetadata().getSchema().getClass("SQLDropIndexTestClass").getClassIndex("SQLDropIndexTestClass.prop1");
Assert.assertNull(index);
}
@Test(dependsOnMethods = "testOldSyntax")
public void testDropIndexWithoutClass() throws Exception {
database.command(new OCommandSQL("CREATE INDEX SQLDropIndexWithoutClass UNIQUE double")).execute();
database.getMetadata().getIndexManager().reload();
OIndex<?> index = database.getMetadata().getIndexManager().getIndex("SQLDropIndexWithoutClass");
Assert.assertNotNull(index);
database.command(new OCommandSQL("DROP INDEX SQLDropIndexWithoutClass")).execute();
database.getMetadata().getIndexManager().reload();
index = database.getMetadata().getIndexManager().getIndex("SQLDropIndexWithoutClass");
Assert.assertNull(index);
}
@Test(dependsOnMethods = "testDropIndexWithoutClass")
public void testDropCompositeIndex() throws Exception {
database.command(new OCommandSQL("CREATE INDEX SQLDropIndexCompositeIndex ON SQLDropIndexTestClass (prop1, prop2) UNIQUE"))
.execute();
database.getMetadata().getIndexManager().reload();
OIndex<?> index = database.getMetadata().getSchema().getClass("SQLDropIndexTestClass")
.getClassIndex("SQLDropIndexCompositeIndex");
Assert.assertNotNull(index);
database.command(new OCommandSQL("DROP INDEX SQLDropIndexCompositeIndex")).execute();
database.getMetadata().getIndexManager().reload();
index = database.getMetadata().getSchema().getClass("SQLDropIndexTestClass").getClassIndex("SQLDropIndexCompositeIndex");
Assert.assertNull(index);
}
@Test(dependsOnMethods = "testDropCompositeIndex")
public void testDropIndexWorkedCorrectly() {
OIndex<?> index = database.getMetadata().getSchema().getClass("SQLDropIndexTestClass")
.getClassIndex("SQLDropIndexTestClass.prop1");
Assert.assertNull(index);
index = database.getMetadata().getSchema().getClass("SQLDropIndexTestClass").getClassIndex("SQLDropIndexWithoutClass");
Assert.assertNull(index);
index = database.getMetadata().getSchema().getClass("SQLDropIndexTestClass").getClassIndex("SQLDropIndexCompositeIndex");
Assert.assertNull(index);
}
}