1
# Copyright (c) 2008,2010 Oracle and/or its affiliates. All rights reserved.
2
# Use is subject to license terms.
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; version 2 of the License.
8
# This program is distributed in the hope that it will be useful, but
9
# WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11
# General Public License for more details.
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301
18
package GenTest::Validator::Transformer2;
21
@ISA = qw(GenTest::Validator GenTest);
26
use GenTest::Constants;
27
use GenTest::Comparator;
28
use GenTest::Simplifier::SQL;
29
use GenTest::Simplifier::Test;
30
use GenTest::Translator;
31
use GenTest::Translator::Mysqldump2ANSI;
32
use GenTest::Translator::Mysqldump2javadb;
33
use GenTest::Translator::MysqlDML2ANSI;
35
use GenTest::SimPipe::Oracle::FullScan;
36
use GenTest::SimPipe::Testcase;
38
my @transformer_names;
40
my $database_created = 0;
43
@transformer_names = (
47
say("Transformer Validator will use the following Transformers: ".join(', ', @transformer_names));
49
foreach my $transformer_name (@transformer_names) {
50
eval ("require GenTest::Transform::'".$transformer_name) or die $@;
51
my $transformer = ('GenTest::Transform::'.$transformer_name)->new();
52
push @transformers, $transformer;
57
my ($validator, $executors, $results) = @_;
59
my $executor = $executors->[0];
60
my $original_result = $results->[0];
61
my $original_query = $original_result->query();
63
if ($database_created == 0) {
64
$executor->dbh()->do("CREATE DATABASE IF NOT EXISTS transforms");
65
$database_created = 1;
68
return STATUS_WONT_HANDLE if $original_query !~ m{^\s*SELECT}sio;
69
return STATUS_WONT_HANDLE if defined $results->[0]->warnings();
70
return STATUS_WONT_HANDLE if $results->[0]->status() != STATUS_OK;
72
my $max_transformer_status;
73
foreach my $transformer (@transformers) {
74
my $transformer_status = $validator->transform($transformer, $executor, $results);
75
$transformer_status = STATUS_OK if ($transformer_status == STATUS_CONTENT_MISMATCH) && ($original_query =~ m{LIMIT}sio);
76
return $transformer_status if $transformer_status > STATUS_CRITICAL_FAILURE;
77
$max_transformer_status = $transformer_status if $transformer_status > $max_transformer_status;
80
return $max_transformer_status > STATUS_SELECT_REDUCTION ? $max_transformer_status - STATUS_SELECT_REDUCTION : $max_transformer_status;
84
my ($validator, $transformer, $executor, $results) = @_;
86
my $original_result = $results->[0];
87
my $original_query = $original_result->query();
89
my ($transform_outcome, $transformed_queries, $transformed_results) = $transformer->transformExecuteValidate($original_query, $original_result, $executor);
90
return $transform_outcome if ($transform_outcome > STATUS_CRITICAL_FAILURE) || ($transform_outcome eq STATUS_OK);
92
say("Original query: $original_query failed transformation with Transformer ".$transformer->name());
93
say("Transformed query: ".join('; ', @$transformed_queries));
95
say(GenTest::Comparator::dumpDiff($original_result, $transformed_results->[0]));
97
my $oracle = GenTest::SimPipe::Oracle::FullScan->new( dsn => $executor->dsn() );
99
my $simplifier_query = GenTest::Simplifier::SQL->new(
101
my $oracle_query = shift;
102
my $oracle_result = $executor->execute($oracle_query, 1);
104
return ORACLE_ISSUE_STATUS_UNKNOWN if $oracle_result->status() != STATUS_OK;
106
my ($oracle_outcome, $oracle_transformed_queries, $oracle_transformed_results) = $transformer->transformExecuteValidate($oracle_query, $oracle_result, $executor);
109
(($oracle_outcome == STATUS_CONTENT_MISMATCH) && ($oracle_query !~ m{LIMIT}sio)) ||
110
($oracle_outcome == STATUS_LENGTH_MISMATCH)
112
return ORACLE_ISSUE_STILL_REPEATABLE;
114
return ORACLE_ISSUE_NO_LONGER_REPEATABLE;
119
my $simplified_query = $simplifier_query->simplify($original_query);
120
my $simplified_result = $executor->execute($simplified_query, 1);
122
if (not defined $simplified_query) {
123
say("Simplification failed -- failure is likely sporadic.");
124
return $transform_outcome;
128
say("Simplified query: $simplified_query");
130
my ($simplified_transform_outcome, $simplified_transformed_queries, $simplified_transformed_results) = $transformer->transformExecuteValidate($simplified_query, $simplified_result, $executor);
132
my $simplified_transformed_queries_str;
133
if (ref($simplified_transformed_queries) eq 'ARRAY') {
134
$simplified_transformed_queries_str = join('; ', @$simplified_transformed_queries);
136
$simplified_transformed_queries_str = $simplified_transformed_queries;
139
say("Simplified transformed query: $simplified_transformed_queries_str");
141
if (defined $simplified_transformed_results->[0]->warnings()) {
142
say("Simplified transformed query produced warnings.");
143
# return STATUS_WONT_HANDLE;
147
$explains[0] = $executor->execute("EXPLAIN ".$simplified_query);
148
foreach my $simplified_transformed_query (@$simplified_transformed_queries) {
149
$executor->execute($simplified_transformed_query);
150
if ($simplified_transformed_query eq $simplified_transformed_results->[0]->query()) {
151
$explains[1] = $executor->execute("EXPLAIN ".$simplified_transformed_query)
155
say("EXPLAIN diff:");
156
say(GenTest::Comparator::dumpDiff(@explains));
158
say("Result set diff:");
159
say(GenTest::Comparator::dumpDiff($simplified_result, $simplified_transformed_results->[0]));
161
my $testcase = GenTest::SimPipe::Testcase->newFromDSN($executor->dsn(), [ $simplified_query ] );
163
my $simplified_testcase = $testcase->simplify($oracle);
165
if (defined $simplified_testcase) {
166
print $simplified_testcase->toString();
168
say("Unable to simplify ...");
169
return STATUS_PERL_FAILURE;
172
return $transform_outcome;