Root/
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 118 119 120 121 122 123 124 | <?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-2010 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_SlugField_Model extends Pluf_Model { public $_model = __CLASS__ ; function init() { $this ->_a[ 'verbose' ] = 'slug' ; $this ->_a[ 'table' ] = 'slug' ; $this ->_a[ 'model' ] = __CLASS__ ; $this ->_a[ 'cols' ] = array ( 'id' => array ( 'type' => 'Pluf_DB_Field_Sequence' , 'blank' => true, ), 'slug_default_length' => array ( 'type' => 'Pluf_DB_Field_Slug' , ), 'slug_custom_legnth' => array ( 'type' => 'Pluf_DB_Field_Slug' , 'widget_attrs' => array ( 'maxlength' => 5, ), ), ); } } class Pluf_Tests_Model_SlugField extends UnitTestCase { function __construct() { parent::__construct( 'Test the slug field.' ); } function testSlugifyLowercase() { $slug = Pluf_DB_Field_Slug::slugify( 'Pluf' ); $this ->assertEqual( 'pluf' , $slug ); } function testSlugifyReplaceWhiteSpaces() { // replaces a white space by the separator $slug = Pluf_DB_Field_Slug::slugify( 'ceondo pluf' ); $this ->assertEqual( 'ceondo-pluf' , $slug ); // replaces several white spaces by a single the separator $slug = Pluf_DB_Field_Slug::slugify( 'ceondo pluf' ); $this ->assertEqual( 'ceondo-pluf' , $slug ); // removes separator at the bound of a string $slug = Pluf_DB_Field_Slug::slugify( ' ceondo pluf' ); $this ->assertEqual( 'ceondo-pluf' , $slug ); $slug = Pluf_DB_Field_Slug::slugify( 'ceondo pluf ' ); $this ->assertEqual( 'ceondo-pluf' , $slug ); } function testSlugifyNonASCII() { // replaces non-ASCII characters by the separator $slug = Pluf_DB_Field_Slug::slugify( 'ceondo,pluf' ); $this ->assertEqual( 'ceondo-pluf' , $slug ); $slug = Pluf_DB_Field_Slug::slugify( 'ceondo€pluf' ); $this ->assertEqual( 'ceondo-pluf' , $slug ); // replaces accents by their equivalent non-accented $slug = Pluf_DB_Field_Slug::slugify( 'éiùàñ' ); $this ->assertEqual( 'eiuan' , $slug ); } function testSlugifyWithCustomSeparator() { $backup = $GLOBALS [ '_PX_config' ]; $GLOBALS [ '_PX_config' ][ 'slug-separator' ] = '_' ; $slug = Pluf_DB_Field_Slug::slugify( 'ceondo pluf' ); $this ->assertEqual( 'ceondo_pluf' , $slug ); $slug = Pluf_DB_Field_Slug::slugify( 'ceondo pluf' ); $this ->assertEqual( 'ceondo_pluf' , $slug ); $GLOBALS [ '_PX_config' ] = $backup ; } function testCreate() { $db = Pluf::db(); $schema = new Pluf_DB_Schema( $db ); $m = new Pluf_Tests_Model_SlugField_Model(); $schema ->model = $m ; $schema ->createTables(); $m ->slug_default_length = 'Pluf, supported by Céondo Ltd.' ; $m ->create(); $this ->assertEqual(1, $m ->id); $m = new Pluf_Tests_Model_SlugField_Model(1); $this ->assertEqual( 'pluf-supported-by-ceondo-ltd' , $m ->slug_default_length); $schema ->dropTables(); } } |