IntegrationBaseTest.php
3.33 KB
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
<?php
/**
* i-Educar - Sistema de gestão escolar
*
* Copyright (C) 2006 Prefeitura Municipal de Itajaí
* <ctima@itajai.sc.gov.br>
*
* Este programa é software livre; você pode redistribuí-lo e/ou modificá-lo
* sob os termos da Licença Pública Geral GNU conforme publicada pela Free
* Software Foundation; tanto a versão 2 da Licença, como (a seu critério)
* qualquer versão posterior.
*
* Este programa é distribuído na expectativa de que seja útil, porém, SEM
* NENHUMA GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU
* ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral
* do GNU para mais detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral do GNU junto
* com este programa; se não, escreva para a Free Software Foundation, Inc., no
* endereço 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA.
*
* @author Eriksen Costa Paixão <eriksen.paixao_bs@cobra.com.br>
* @category i-Educar
* @license @@license@@
* @package IntegrationTests
* @since Arquivo disponível desde a versão 1.1.0
* @version $Id$
*/
require_once 'PHPUnit/Extensions/Database/TestCase.php';
require_once 'CoreExt/DataMapper.php';
/**
* IntegrationBaseTest abstract class.
*
* Cria um ambiente de testes de integração com um banco de dados sqlite em
* memória. Útil para os testes dos novos componentes de domínio.
*
* @author Eriksen Costa Paixão <eriksen.paixao_bs@cobra.com.br>
* @category i-Educar
* @license @@license@@
* @package IntegrationTests
* @since Classe disponível desde a versão 1.1.0
* @version @@package_version@@
*/
abstract class IntegrationBaseTest extends PHPUnit_Extensions_Database_TestCase
{
/**
* Objeto de conexão com o banco de dados que será utilizado tanto pelas
* classes da aplicação quanto pelos testes de integração.
*
* @var CustomPdo
*/
protected $db = NULL;
/**
* Construtor.
*/
public function __construct()
{
$this->db = new CustomPdo('sqlite::memory:');
}
/**
* Usa o setUp() para configurar a todas as instâncias de CoreExt_DataMapper
* que usem o adapter de banco dessa classe.
*/
protected function setUp()
{
parent::setUp();
CoreExt_DataMapper::setDefaultDbAdapter($this->getDbAdapter());
}
/**
* Getter.
* @return CustomPdo
*/
protected function getDbAdapter()
{
return $this->db;
}
/**
* Retorna a conexão usada pelos testes de integração do DbUnit. Note que
* a conexão é criada com o objeto PDO encapsulado em CustomPdo.
*
* @return PHPUnit_Extensions_Database_DB_DefaultDatabaseConnection
*/
protected function getConnection()
{
return $this->createDefaultDBConnection($this->db->getPdo(), 'testdb');
}
/**
* Retorna o caminho absoluto para um arquivo fixture em unit/CoreExt/.
*
* @param string $filename
* @return string
*/
public function getFixture($filename)
{
$path = dirname(__FILE__);
return $path . '/unit/CoreExt/_fixtures/' . $filename;
}
/**
* Retorna o caminho absoluto para um arquivo fixture dentro do diretório
* _tests de um módulo.
*
* @param string $filename
* @return string
*/
public function getFixtureForModule($filename, $module)
{
$path = PROJECT_ROOT . DS . 'modules' . DS . $module . DS . '_tests';
return $path . DS . $filename;
}
}