| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- <?php
- /*
- * This file is part of Mustache.php.
- *
- * (c) 2013 Justin Hileman
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- /**
- * A PHPUnit test case wrapping the Mustache Spec
- *
- * @group mustache-spec
- * @group functional
- */
- class Mustache_Test_FiveThree_Functional_MustacheSpecTest extends PHPUnit_Framework_TestCase
- {
- private static $mustache;
- public static function setUpBeforeClass()
- {
- self::$mustache = new Mustache_Engine;
- }
- /**
- * For some reason data providers can't mark tests skipped, so this test exists
- * simply to provide a 'skipped' test if the `spec` submodule isn't initialized.
- */
- public function testSpecInitialized()
- {
- if (!file_exists(dirname(__FILE__).'/../../../../../vendor/spec/specs/')) {
- $this->markTestSkipped('Mustache spec submodule not initialized: run "git submodule update --init"');
- }
- }
- /**
- * @group lambdas
- * @dataProvider loadLambdasSpec
- */
- public function testLambdasSpec($desc, $source, $partials, $data, $expected)
- {
- $template = self::loadTemplate($source, $partials);
- $this->assertEquals($expected, $template($this->prepareLambdasSpec($data)), $desc);
- }
- public function loadLambdasSpec()
- {
- return $this->loadSpec('~lambdas');
- }
- /**
- * Extract and lambdafy any 'lambda' values found in the $data array.
- */
- private function prepareLambdasSpec($data)
- {
- foreach ($data as $key => $val) {
- if ($key === 'lambda') {
- if (!isset($val['php'])) {
- $this->markTestSkipped(sprintf('PHP lambda test not implemented for this test.'));
- }
- $func = $val['php'];
- $data[$key] = function($text = null) use ($func) {
- return eval($func);
- };
- } elseif (is_array($val)) {
- $data[$key] = $this->prepareLambdasSpec($val);
- }
- }
- return $data;
- }
- /**
- * Data provider for the mustache spec test.
- *
- * Loads YAML files from the spec and converts them to PHPisms.
- *
- * @access public
- * @return array
- */
- private function loadSpec($name)
- {
- $filename = dirname(__FILE__) . '/../../../../../vendor/spec/specs/' . $name . '.yml';
- if (!file_exists($filename)) {
- return array();
- }
- $data = array();
- $yaml = new sfYamlParser;
- $file = file_get_contents($filename);
- // @hack: pre-process the 'lambdas' spec so the Symfony YAML parser doesn't complain.
- if ($name === '~lambdas') {
- $file = str_replace(" !code\n", "\n", $file);
- }
- $spec = $yaml->parse($file);
- foreach ($spec['tests'] as $test) {
- $data[] = array(
- $test['name'] . ': ' . $test['desc'],
- $test['template'],
- isset($test['partials']) ? $test['partials'] : array(),
- $test['data'],
- $test['expected'],
- );
- }
- return $data;
- }
- private static function loadTemplate($source, $partials)
- {
- self::$mustache->setPartials($partials);
- return self::$mustache->loadTemplate($source);
- }
- }
|