Pergunta

Meu problema é que preciso listar todas as chamadas para um objeto simulado, porque preciso verificá-las.Não encontrei nada sobre esse recurso na documentação do SimpleTest.:S

Talvez haja outra maneira de testar meu código:

class Clean_Collection_Tree_NestedArrayParser {

    protected $path = array();
    protected $depth = -1;

    /** @var Clean_Collection_Tree_MapTreeInterface */
    protected $tree;

    public function setBasePath(array $path) {
        $this->path = $path;
    }

    public function setTree(Clean_Collection_Tree_MapTreeInterface $tree) {
        $this->tree = $tree;
    }

    public function parse($subject) {
        $this->parseArray($subject);
    }

    public function parseArray(array $array) {
        ++$this->depth;
        foreach ($array as $key => $value) {
            $this->path[$this->depth] = $key;
            if (is_array($value)) {
                $this->tree->put($this->path, new Clean_Collection_Map_Map());
                $this->parseArray($value);
            } else
                $this->tree->put($this->path, $value);
        }
        if (!empty($array))
            array_pop($this->path);
        --$this->depth;
    }

}

Este é um analisador aguardando um array aninhado a partir do qual pretendo criar um objeto Map Tree.Eu injeto a árvore real com setTree(Clean_Collection_Tree_MapTreeInterface $árvore) e a interface da árvore de mapas é:

interface Clean_Collection_Tree_MapTreeInterface extends Clean_Collection_CollectionInterface {

    public function putAll(array $array);

    public function put(array $path, $value);

    public function get(array $path);

    public function getAll(array $pathes);

    public function removeAll(array $pathes);

    public function remove(array $path);

    public function contains(array $path);
}

O analisador usa apenas o colocar(array $caminho, $valor) método.Portanto, listar todos os métodos put chamados me mostrará o que deu errado no analisador.(Se o SimpleMock não tiver esse recurso posso criar meu próprio objeto simulado que implementa a interface.Eu estou trabalhando nisso.)

Foi útil?

Solução

O problema está no design da classe SimpleMock:

protected function addCall($method, $args) {

    if (! isset($this->call_counts[$method])) {
        $this->call_counts[$method] = 0;
    }
    $this->call_counts[$method]++;
}

Eles deveriam ter criado uma classe de logger para registrar propriedades de chamada em vez de definir uma propriedade no SimpleMock ...Podemos criar uma solução estendendo a classe SimpleMock:

class LoggedMock extends SimpleMock {

    protected $invokes = array();

    public function &invoke($method, $args) {
        $this->invokes[] = array($method, $args);
        return parent::invoke($method, $args);
    }

    public function getMockInvokes() {
        return $this->invokes;
    }

}

e defina-o como classe simulada base:

    require_once __DIR__.'simpletest/autorun.php';
    SimpleTest::setMockBaseClass('LoggedMock');

Depois disso, podemos obter a lista de invocação com o $mockObj->getMockInvokes().

Editar:não podemos estender o addCall, porque na primeira linha do método invocar o nome do método é convertido para lowerCase, portanto, ao estender o addCall só podemos registrar o formato lowerCase, e não o camelCase.(Acho que converter letras minúsculas é um erro...)

Criei um teste para demonstração:

interface Nike {

    public function justDoIt();
}

class NikeUser {

    protected $nike;

    public function setNike(Nike $nike) {
        $this->nike = $nike;
    }

    public function doIt() {
        $this->nike->justDoIt();
    }

}

Mock::generate('Nike', 'MockNike');

class NikeUserTest extends UnitTestCase {

    public function testDoItButWeDontWantJustDoIt() {
        $mockNike = new MockNike();

        $nikeUser = new NikeUser();
        $nikeUser->setNike($mockNike);

        $expectedInvokes = array();

        $nikeUser->doIt();
        $expectedInvokes[] = array('justDoIt', array());
        $this->assertEqual($expectedInvokes, $mockNike->getMockInvokes());
    }

}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top