/* * 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.facebook.presto.tests; import com.facebook.presto.Session; import com.facebook.presto.connector.ConnectorId; import com.facebook.presto.metadata.SessionPropertyManager; import com.facebook.presto.spi.type.Type; import com.facebook.presto.testing.LocalQueryRunner; import com.facebook.presto.testing.MaterializedResult; import com.facebook.presto.testing.TestingAccessControlManager; import com.facebook.presto.tpch.TpchConnectorFactory; import com.google.common.collect.ImmutableMap; import org.intellij.lang.annotations.Language; import org.testng.annotations.AfterClass; import org.testng.annotations.BeforeClass; import java.util.List; import static com.facebook.presto.testing.TestingSession.TESTING_CATALOG; import static com.facebook.presto.testing.TestingSession.testSessionBuilder; import static com.facebook.presto.tpch.TpchMetadata.TINY_SCHEMA_NAME; public class TestQueryPlanDeterminism extends AbstractTestQueries { private PlanDeterminismChecker determinismChecker; protected TestQueryPlanDeterminism() { super(TestQueryPlanDeterminism::createLocalQueryRunner); } @BeforeClass public void setUp() { determinismChecker = new PlanDeterminismChecker((LocalQueryRunner) getQueryRunner()); } @AfterClass(alwaysRun = true) public void tearDown() { determinismChecker = null; } public static LocalQueryRunner createLocalQueryRunner() { Session defaultSession = testSessionBuilder() .setCatalog("local") .setSchema(TINY_SCHEMA_NAME) .build(); LocalQueryRunner localQueryRunner = new LocalQueryRunner(defaultSession); // add the tpch catalog // local queries run directly against the generator localQueryRunner.createCatalog( defaultSession.getCatalog().get(), new TpchConnectorFactory(1), ImmutableMap.<String, String>of()); localQueryRunner.getMetadata().addFunctions(CUSTOM_FUNCTIONS); SessionPropertyManager sessionPropertyManager = localQueryRunner.getMetadata().getSessionPropertyManager(); sessionPropertyManager.addSystemSessionProperties(TEST_SYSTEM_PROPERTIES); sessionPropertyManager.addConnectorSessionProperties(new ConnectorId(TESTING_CATALOG), TEST_CATALOG_PROPERTIES); return localQueryRunner; } @Override protected MaterializedResult computeActual(@Language("SQL") String sql) { determinismChecker.checkPlanIsDeterministic(sql); return super.computeActual(sql); } @Override protected MaterializedResult computeActual(Session session, @Language("SQL") String sql) { determinismChecker.checkPlanIsDeterministic(session, sql); return super.computeActual(session, sql); } @Override protected void assertQuery(@Language("SQL") String sql) { determinismChecker.checkPlanIsDeterministic(sql); } @Override protected void assertQuery(Session session, @Language("SQL") String sql) { determinismChecker.checkPlanIsDeterministic(session, sql); } @Override public void assertQueryOrdered(@Language("SQL") String sql) { determinismChecker.checkPlanIsDeterministic(sql); } @Override protected void assertQuery(@Language("SQL") String actual, @Language("SQL") String expected) { determinismChecker.checkPlanIsDeterministic(actual); } @Override protected void assertQuery(Session session, @Language("SQL") String actual, @Language("SQL") String expected) { determinismChecker.checkPlanIsDeterministic(session, actual); } @Override protected void assertQueryOrdered(@Language("SQL") String actual, @Language("SQL") String expected) { determinismChecker.checkPlanIsDeterministic(actual); } @Override protected void assertQueryOrdered(Session session, @Language("SQL") String actual, @Language("SQL") String expected) { determinismChecker.checkPlanIsDeterministic(session, actual); } @Override protected void assertUpdate(@Language("SQL") String actual, @Language("SQL") String expected) { determinismChecker.checkPlanIsDeterministic(actual); } @Override protected void assertUpdate(Session session, @Language("SQL") String actual, @Language("SQL") String expected) { determinismChecker.checkPlanIsDeterministic(session, actual); } @Override protected void assertUpdate(@Language("SQL") String sql) { determinismChecker.checkPlanIsDeterministic(sql); } @Override protected void assertUpdate(Session session, @Language("SQL") String sql) { determinismChecker.checkPlanIsDeterministic(session, sql); } @Override protected void assertUpdate(@Language("SQL") String sql, long count) { determinismChecker.checkPlanIsDeterministic(sql); } @Override protected void assertUpdate(Session session, @Language("SQL") String sql, long count) { determinismChecker.checkPlanIsDeterministic(session, sql); } @Override protected void assertQueryFails(@Language("SQL") String sql, @Language("RegExp") String expectedMessageRegExp) { super.assertQueryFails(sql, expectedMessageRegExp); } @Override protected void assertQueryFails(Session session, @Language("SQL") String sql, @Language("RegExp") String expectedMessageRegExp) { super.assertQueryFails(session, sql, expectedMessageRegExp); } @Override protected void assertAccessAllowed(@Language("SQL") String sql, TestingAccessControlManager.TestingPrivilege... deniedPrivileges) { } @Override protected void assertAccessAllowed(Session session, @Language("SQL") String sql, TestingAccessControlManager.TestingPrivilege... deniedPrivileges) { } @Override protected void assertAccessDenied(@Language("SQL") String sql, @Language("RegExp") String exceptionsMessageRegExp, TestingAccessControlManager.TestingPrivilege... deniedPrivileges) { } @Override protected void assertAccessDenied(Session session, @Language("SQL") String sql, @Language("RegExp") String exceptionsMessageRegExp, TestingAccessControlManager.TestingPrivilege... deniedPrivileges) { } @Override protected void assertTableColumnNames(String tableName, String... columnNames) { } @Override protected MaterializedResult computeExpected(@Language("SQL") String sql, List<? extends Type> resultTypes) { determinismChecker.checkPlanIsDeterministic(sql); return super.computeExpected(sql, resultTypes); } }