Pluf Framework

Pluf Framework Git Source Tree


Root/src/Pluf/Tests/Model/Schema.php

<?php
/* -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
# ***** BEGIN LICENSE BLOCK *****
# This file is part of Plume Framework, a simple PHP Application Framework.
# Copyright (C) 2001-2007 Loic d'Anterroches and contributors.
#
# Plume Framework is free software; you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2.1 of the License, or
# (at your option) any later version.
#
# Plume Framework 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 Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
#
# ***** END LICENSE BLOCK ***** */

class Pluf_Tests_Model_Schema_Model extends Pluf_Model
{
    public $_model = __CLASS__; 

    function init()
    {
        $this->_a['verbose'] = 'compressed';
        $this->_a['table'] = 'compressed';
        $this->_a['model'] = __CLASS__;
        $this->_a['cols'] = array(
                             // It is mandatory to have an "id" column.
                            'id' =>
                            array(
                                  'type' => 'Pluf_DB_Field_Sequence',
                                  //It is automatically added.
                                  'blank' => true, 
                                  ),
                            'column1' =>
                            array(
                                  'type' => 'Pluf_DB_Field_Varchar',
                                  ),
                            'column2' =>
                            array(
                                  'type' => 'Pluf_DB_Field_Varchar',
                                  ),
                            'column3' =>
                            array(
                                  'type' => 'Pluf_DB_Field_Varchar',
                                  ),
                            );
        $this->_a['idx'] = array(                           
                            'test_idx' =>
                            array(
                                  'col' => 'column1, column2, column3',
                                  'type' => 'unique',
                                  ),
                            );
        
    }
}


class Pluf_Tests_Model_Schema extends UnitTestCase {
 
    function __construct() 
    {
        parent::__construct('Test the compressed field.');
    }

    function testCreate()
    {
        $db = Pluf::db();
        $schema = new Pluf_DB_Schema($db);
        $m = new Pluf_Tests_Model_Schema_Model();
        $schema->model = $m;
        $schema->createTables();
        $m->column1 = 'Youplaboum';
        $m->column2 = 'Youplaboum';
        $m->column3 = 'Youplaboum';
        $m->create();
        $this->assertEqual(1, $m->id);
        $m = new Pluf_Tests_Model_Schema_Model();
        $m->column1 = 'Youplaboum';
        $m->column2 = 'Youplaboum';
        $m->column3 = 'Youplaboum';
        try {
            $m->create();
            $this->assertNotEqual(2, $m->id, 'Should not be able to create.');
        } catch (Exception $e) {
            // do nothing
        }
        $schema->dropTables();
    }
}

Archive Download this file

Branches

Tags

Number of commits:
Page rendered in 0.10847s using 11 queries.