| 
<?php
 /*
 * BootHelp - Bootstrap Helpers written in PHP
 *
 * (The MIT License)
 *
 * Copyright (c) 2015 Jorge Cobis <jcobis@gmail.com / http://twitter.com/cobisja>.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
 
 namespace BootHelp\Tests;
 
 use cobisja\BootHelp\ProgressBar;
 
 
 class ProgressBarTest extends \PHPUnit_Framework_TestCase {
 public function testWithPercentageOption() {
 /**
 * It should generates:
 *
 * <div class="progress">
 *     <div aria-valuemax="100" aria-valuemin="0" aria-valuenow="30" style="width: 30%" role="progressbar" class="progress-bar">
 *         <span class="sr-only">30%</span>
 *     </div>
 * </div>
 */
 $percentage = 30;
 $progress_bar = new ProgressBar(['percentage'=>$percentage]);
 $html = $progress_bar->get_html();
 $this->assertTrue($html->is_a('div', ['class'=>'progress']));
 
 $bar = $html->get_child(0);
 $this->assertTrue($bar->is_a('div', ['style'=>"width: $percentage%", 'role'=>'progressbar', 'class'=>'progress-bar']));
 $this->assertTrue($bar->has_a_child_of_type('span', ['class'=>'sr-only']));
 $this->assertEquals($percentage . '%', $bar->get_child(0)->get_content());
 }
 
 public function testWithBarLabel() {
 /**
 * It should generates:
 *
 * <div class="progress">
 *     <div aria-valuemax="100" aria-valuemin="0" aria-valuenow="30" style="width: 30%" role="progressbar" class="progress-bar">
 *         30%
 *     </div>
 * </div>
 */
 $percentage = 30;
 $progress_bar = new ProgressBar(['percentage'=>$percentage, 'label'=>true]);
 $html = $progress_bar->get_html();
 $this->assertTrue($html->is_a('div', ['class'=>'progress']));
 
 $bar = $html->get_child(0);
 $this->assertTrue($bar->is_a('div', ['style'=>"width: $percentage%", 'role'=>'progressbar', 'class'=>'progress-bar']));
 $this->assertEquals($percentage . '%', $bar->get_content());
 }
 
 public function testWithCustomizedBarLabel() {
 /**
 * It should generates:
 *
 * <div class="progress">
 *     <div aria-valuemax="100" aria-valuemin="0" aria-valuenow="30" style="width: 30%" role="progressbar" class="progress-bar">
 *         thirty percent
 *     </div>
 * </div>
 */
 $percentage = 30;
 $customized_label = 'thirty percent';
 $progress_bar = new ProgressBar(['percentage'=>$percentage, 'label'=>$customized_label]);
 $html = $progress_bar->get_html();
 $this->assertTrue($html->is_a('div', ['class'=>'progress']));
 
 $bar = $html->get_child(0);
 $this->assertTrue($bar->is_a('div', ['style'=>"width: $percentage%", 'role'=>'progressbar', 'class'=>'progress-bar']));
 $this->assertEquals($customized_label, $bar->get_content());
 }
 
 /**
 * @dataProvider get_contexts
 */
 public function testSettingContextualOption($context) {
 /**
 * It should generates:
 *
 * <div class="progress">
 *     <div class="progress-bar progress-bar-{$context}" aria-valuemax="100" aria-valuemin="0" aria-valuenow="30" style="width: 30%" role="progressbar">
 *         <span class="sr-only">30%</span>
 *     </div>
 * </div>
 */
 $percentage = 30;
 $progress_bar = new ProgressBar(['percentage'=>$percentage, 'context'=>$context]);
 $html = $progress_bar->get_html();
 $this->assertTrue($html->is_a('div', ['class'=>'progress']));
 
 $bar = $html->get_child(0);
 $this->assertTrue($bar->is_a('div', ['style'=>"width: $percentage%", 'role'=>'progressbar']));
 $this->assertTrue($bar->has_attribute('class',['progress-bar', 'progress-bar-' . $context]));
 }
 
 public function testSettingStripedOption() {
 /**
 * It should generates:
 *
 * <div class="progress">
 *     <div class="progress-bar progress-bar-striped" aria-valuemax="100" aria-valuemin="0" aria-valuenow="30" style="width: 30%" role="progressbar">
 *         <span class="sr-only">30%</span>
 *     </div>
 * </div>
 */
 $percentage = 30;
 $progress_bar = new ProgressBar(['percentage'=>$percentage, 'striped'=>true]);
 $html = $progress_bar->get_html();
 $this->assertTrue($html->is_a('div', ['class'=>'progress']));
 
 $bar = $html->get_child(0);
 $this->assertTrue($bar->is_a('div', ['style'=>"width: $percentage%", 'role'=>'progressbar']));
 $this->assertTrue($bar->has_attribute('class',['progress-bar', 'progress-bar-striped' ]));
 }
 
 public function testSettingAnimatedOption() {
 /**
 * It should generates:
 *
 * <div class="progress">
 *     <div class="progress-bar progress-bar-striped active" aria-valuemax="100" aria-valuemin="0" aria-valuenow="30" style="width: 30%" role="progressbar">
 *         <span class="sr-only">30%</span>
 *     </div>
 * </div>
 */
 $percentage = 30;
 $progress_bar = new ProgressBar(['percentage'=>$percentage, 'animated'=>true]);
 $html = $progress_bar->get_html();
 $this->assertTrue($html->is_a('div', ['class'=>'progress']));
 
 $bar = $html->get_child(0);
 $this->assertTrue($bar->is_a('div', ['style'=>"width: $percentage%", 'role'=>'progressbar']));
 $this->assertTrue($bar->has_attribute('class', 'active progress-bar progress-bar-striped'));
 }
 
 public function testStackedProgressBars() {
 /**
 * It should generates:
 *
 * <div class="progress">
 *     <div aria-valuemax="100" aria-valuemin="0" aria-valuenow="30" style="width: 30%" role="progressbar" class="progress-bar progress-bar-success">
 *         Completed
 *     </div>
 *     <div aria-valuemax="100" aria-valuemin="0" aria-valuenow="40" style="width: 40%" role="progressbar" class="progress-bar progress-bar-warning progress-bar-striped active">
 *         Pending
 *     </div>
 * </div>
 */
 $progress_bar = new ProgressBar([
 ['percentage'=>30, 'context'=>'success', 'label'=>'Completed'],
 ['percentage'=>40, 'context'=>'warning', 'animated'=>true, 'label'=>'Pending']
 ]);
 $html = $progress_bar->get_html();
 $this->assertTrue($html->is_a('div', ['class'=>'progress']));
 $this->assertTrue(2 === $html->number_of_children());
 $bar_1 = $html->get_child(0);
 $bar_2 = $html->get_child(1);
 
 $this->assertTrue($bar_1->is_a('div', ['style'=>"width: 30%", 'role'=>'progressbar']));
 $this->assertTrue($bar_2->is_a('div', ['style'=>"width: 40%", 'role'=>'progressbar']));
 }
 
 public function testWithExtraOptions() {
 /**
 * It should generates:
 *
 * <div id="container" class="en progress">
 *     <div data-js="1" id="my-bar" class="progress-bar progress-bar-striped active" aria-valuemax="100" aria-valuemin="0" aria-valuenow="30" style="width: 30%" role="progressbar">
 *         <span class="sr-only">30%</span>
 *     </div>
 * </div>
 */
 $progress_bar = new ProgressBar(
 ['percentage'=>30, 'id'=>'my-bar', 'data-js'=>1],
 ['id'=>'container', 'class'=>'en']
 );
 $html = $progress_bar->get_html();
 $this->assertTrue($html->is_a('div', ['class'=>'progress en', 'id'=>'container']));
 
 $bar_container = $html->get_child(0);
 $this->assertTrue($bar_container->is_a('div', ['style'=>"width: 30%", 'role'=>'progressbar', 'class'=>'progress-bar']));
 $this->assertTrue($bar_container->has_attribute('data-js', 1) && $bar_container->has_attribute('id', 'my-bar'));
 }
 
 
 public function get_contexts() {
 return [ ['success'], ['info'], ['warning'], ['danger'] ];
 }
 }
 
 |