summaryrefslogtreecommitdiffstats
path: root/tests/big_record.pl
diff options
context:
space:
mode:
Diffstat (limited to 'tests/big_record.pl')
-rwxr-xr-xtests/big_record.pl111
1 files changed, 111 insertions, 0 deletions
diff --git a/tests/big_record.pl b/tests/big_record.pl
new file mode 100755
index 00000000..639e305b
--- /dev/null
+++ b/tests/big_record.pl
@@ -0,0 +1,111 @@
+#!/usr/bin/env perl
+
+# Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; version 2 of the License.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1335 USA
+
+# This is a test with stores big records in a blob.
+# Note that for the default test the mysql server should have been
+# started with at least 'mysqld --max_allowed_packet=30M' and you should have
+# at least 256M memory in your computer.
+
+use DBI;
+use Getopt::Long;
+
+$opt_host="";
+$opt_user=$opt_password="";
+$opt_db="test";
+$opt_rows=20; # Test of blobs up to ($rows-1)*100000+1 bytes
+$opt_compress=0;
+$opt_table="test_big_record";
+$opt_loop_count=100000; # Change this to make test harder/easier
+
+GetOptions("host=s","db=s","user=s", "password=s", "table=s", "rows=i",
+ "compress", "loop-count=i") || die "Aborted";
+
+print "Connection to database $test_db\n";
+
+$extra_options="";
+$extra_options.=":mariadb_compression=1" if ($opt_compress);
+
+$dbh = DBI->connect("DBI:MariaDB:$opt_db:$host$extra_options",$opt_user,$opt_password) || die "Can't connect: $DBI::errstr\n";
+
+$dbh->do("drop table if exists $opt_table");
+
+print "Creating table $opt_table\n";
+
+($dbh->do("\
+CREATE TABLE $opt_table (
+ auto int(5) unsigned NOT NULL DEFAULT '0' auto_increment,
+ test longblob,
+ PRIMARY KEY (auto))")) or die $DBI::errstr;
+
+print "Inserting $opt_rows records\n";
+
+$|=1; # Flush output to stdout to be able to monitor process
+
+for ($i=0 ; $i < $opt_rows ; $i++)
+{
+ $tmp= chr(65+($i % 16)) x ($i*100000+1);
+ $tmp= $dbh->quote($tmp);
+ $dbh->do("insert into $opt_table (test) values ($tmp)") or die $DBI::errstr;
+ print ".";
+}
+
+print "\nReading records\n";
+
+$sth=$dbh->prepare("select * from $opt_table", { "mariadb_use_result" => 1}) or die $dbh->errstr;
+
+$sth->execute() or die $sth->errstr;
+
+$i=0;
+while (($row = $sth->fetchrow_arrayref))
+{
+ die "Record $i had wrong data in blob" if ($row->[1] ne (chr(65+($i % 16)) x ($i*100000+1)));
+ $i++;
+}
+
+die "Didn't get all rows from server" if ($i != $opt_rows);
+
+#
+# Test by insert/updating/deleting random rows for a while
+#
+
+print "Testing insert/update/delete\n";
+
+$max_row_id= $rows;
+for ($i= 0 ; $i < $opt_loop_count ; $i++)
+{
+ $length= int(rand 65535);
+ $tmp= chr(65+($i % 16)) x $length;
+ $tmp= $dbh->quote($tmp);
+ $dbh->do("insert into $opt_table (test) values ($tmp)") or die $DBI::errstr;
+ $max_row_id++;
+ $length=int(rand 65535);
+ $tmp= chr(65+($i % 16)) x $length;
+ $tmp= $dbh->quote($tmp);
+ $id= int(rand $max_row_id);
+ $dbh->do("update $opt_table set test= $tmp where auto= $id") or die $DBI::errstr;
+ if (($i % 2) == 1)
+ {
+ $id= int(rand $max_row_id);
+ $dbh->do("delete from $opt_table where auto= $id") or die $DBI::errstr;
+ }
+ print "." if ($i % ($opt_loop_count/100) == 1);
+}
+
+# $dbh->do("drop table $opt_table") or die $DBI::errstr;
+
+print "\nTest ok\n";
+exit 0;