File: LobLengthTest.java

package info (click to toggle)
derby 10.14.2.0-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye
  • size: 78,896 kB
  • sloc: java: 691,930; sql: 42,686; xml: 20,511; sh: 3,373; sed: 96; makefile: 60
file content (117 lines) | stat: -rw-r--r-- 3,812 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*

   Derby - Class org.apache.derbyTesting.functionTests.tests.jdbcapi.LobLengthTest

   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

   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 org.apache.derbyTesting.functionTests.tests.jdbcapi;

import java.sql.PreparedStatement;
import java.sql.Statement;
import junit.framework.Test;
import org.apache.derbyTesting.functionTests.util.streams.LoopingAlphabetStream;
import org.apache.derbyTesting.junit.BaseJDBCTestCase;
import org.apache.derbyTesting.junit.TestConfiguration;

/**
 * This tests a fix for a defect (DERBY-121) where the server and
 * client were processing lob lengths incorrectly.  For lob lengths
 * that are represented by 24 or more bits, the server and Derby
 * client were doing incorrect bit-shifting.  This test makes sure
 * that problem no longer occurs.
 */

public class LobLengthTest extends BaseJDBCTestCase {

    /**
     * Creates a new instance of LobLengthTest
     *
     * @param name name of the test.
     */
    public LobLengthTest(String name)
    {
        super(name);
    }

    
    public static Test suite() 
    {
        return TestConfiguration.defaultSuite(LobLengthTest.class);
    }


    /**
     * Create a JDBC connection using the arguments passed
     * in from the harness, and create the table to be used by the test.
     */
    public void setUp() throws Exception
    {
        getConnection().setAutoCommit(false);

        // Create a test table.
        Statement st = createStatement();
        st.execute("create table lobTable100M(bl blob(100M))");
        st.close();
    }


    /**
     * Cleanup: Drop table and close connection.
     */
    public void tearDown() throws Exception 
    {
        Statement st = createStatement();
        st.execute("drop table lobTable100M");
        st.close();

        commit();
        super.tearDown();
    }


    /**
     * There was a defect (DERBY-121) where the server and client
     * were processing lob lengths incorrectly.  For lob lengths
     * that are represented by 24 or more bits, the server and
     * Derby client were doing incorrect bit-shifting.  This
     * test makes sure that problem no longer occurs.
     */
    public void testLongLobLengths() throws Exception
    {
        PreparedStatement pSt = prepareStatement(
            "insert into lobTable100M(bl) values (?)");

        // The error we're testing occurs when the server
        // is shifting bits 24 and higher of the lob's
        // length (in bytes).  This means that, in order
        // to check for the error, we have to specify a
        // lob length (in bytes) that requires at least
        // 24 bits to represent.  Thus for a blob the
        // length of the test data must be specified as
        // at least 2^24 bytes (hence the '16800000' in
        // the next line).
        int lobSize = 16800000;
        pSt.setBinaryStream(1,
            new LoopingAlphabetStream(lobSize), lobSize);

        // Now try the insert; this is where the server processes
        // the lob length.
        pSt.execute();
        pSt.close();
    }
}