Package org.tmatesoft.sqljet.issues.length

Source Code of org.tmatesoft.sqljet.issues.length.LengthTest

/**
* LengthTest.java
* Copyright (C) 2009-2010 TMate Software Ltd
*
* 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.
*
* For information on how to redistribute this software under
* the terms of a license other than GNU General Public License
* contact TMate Software at support@sqljet.com
*/
package org.tmatesoft.sqljet.issues.length;

import org.junit.Assert;
import org.junit.Test;
import org.tmatesoft.sqljet.core.AbstractNewDbTest;
import org.tmatesoft.sqljet.core.SqlJetException;
import org.tmatesoft.sqljet.core.SqlJetTransactionMode;
import org.tmatesoft.sqljet.core.table.ISqlJetTable;
import org.tmatesoft.sqljet.core.table.ISqlJetTransaction;
import org.tmatesoft.sqljet.core.table.SqlJetDb;

/**
* @author TMate Software Ltd.
* @author Sergey Scherbina (sergey.scherbina@gmail.com)
*
*/
public class LengthTest extends AbstractNewDbTest {

    @Test
    public void testLength() throws SqlJetException {
        try {
            db.runTransaction(new ISqlJetTransaction() {
                public Object run(SqlJetDb db) throws SqlJetException {
                    final String sql = "CREATE TABLE contacts ( " + "id INTEGER PRIMARY KEY,"
                            + "name TEXT NOT NULL COLLATE NOCASE," + "phone TEXT NOT NULL DEFAULT 'UNKNOWN',"
                            + "UNIQUE (name,phone)," + "CHECK(LENGTH(phone)>=7) );";
                    db.createTable(sql);
                    return true;
                }
            }, SqlJetTransactionMode.WRITE);
        } catch (Exception e) {
            e.printStackTrace();
        }
        final ISqlJetTable table = db.getTable("contacts");
        final String sql = table.getDefinition().toSQL();
        //Logger.getAnonymousLogger().info(sql);

        Assert.assertTrue(sql.matches("(?i).*LENGTH\\s*\\(\\s*phone\\s*\\).*"));
        Assert.assertFalse(sql.matches("(?i).*LENGTH\\s*\\(\\s*\\).*"));

    }

}
TOP

Related Classes of org.tmatesoft.sqljet.issues.length.LengthTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.