154 lines
6.0 KiB
PHP
154 lines
6.0 KiB
PHP
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Style\ConditionalFormatting\Wizard;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Exception;
|
|
use PhpOffice\PhpSpreadsheet\Style\Conditional;
|
|
use PhpOffice\PhpSpreadsheet\Style\ConditionalFormatting\Wizard;
|
|
use PhpOffice\PhpSpreadsheet\Style\Style;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class TextValueWizardTest extends TestCase
|
|
{
|
|
/**
|
|
* @var Style
|
|
*/
|
|
protected $style;
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $range = '$C$3:$E$5';
|
|
|
|
/**
|
|
* @var Wizard
|
|
*/
|
|
protected $wizardFactory;
|
|
|
|
protected function setUp(): void
|
|
{
|
|
$this->wizardFactory = new Wizard($this->range);
|
|
$this->style = new Style();
|
|
}
|
|
|
|
public function testTextContainsWizardWithText(): void
|
|
{
|
|
$ruleType = Wizard::TEXT_VALUE;
|
|
/** @var Wizard\TextValue $textWizard */
|
|
$textWizard = $this->wizardFactory->newRule($ruleType);
|
|
self::assertInstanceOf(Wizard\TextValue::class, $textWizard);
|
|
|
|
$textWizard->setStyle($this->style);
|
|
$textWizard->contains('LL');
|
|
|
|
$conditional = $textWizard->getConditional();
|
|
self::assertSame(Conditional::CONDITION_CONTAINSTEXT, $conditional->getConditionType());
|
|
self::assertSame(Conditional::OPERATOR_CONTAINSTEXT, $conditional->getOperatorType());
|
|
self::assertSame('LL', $conditional->getText());
|
|
$conditions = $conditional->getConditions();
|
|
self::assertSame(['NOT(ISERROR(SEARCH("LL",C3)))'], $conditions);
|
|
|
|
$newWizard = Wizard::fromConditional($conditional, $this->range);
|
|
$newWizard->getConditional();
|
|
self::assertEquals($newWizard, $textWizard, 'fromConditional() Failure');
|
|
}
|
|
|
|
public function testTextContainsWizardWithCellReference(): void
|
|
{
|
|
$ruleType = Wizard::TEXT_VALUE;
|
|
/** @var Wizard\TextValue $textWizard */
|
|
$textWizard = $this->wizardFactory->newRule($ruleType);
|
|
self::assertInstanceOf(Wizard\TextValue::class, $textWizard);
|
|
|
|
$textWizard->setStyle($this->style);
|
|
$textWizard->contains('$A1', Wizard::VALUE_TYPE_CELL);
|
|
|
|
$conditional = $textWizard->getConditional();
|
|
self::assertSame(Conditional::CONDITION_CONTAINSTEXT, $conditional->getConditionType());
|
|
self:self::assertSame(Conditional::OPERATOR_CONTAINSTEXT, $conditional->getOperatorType());
|
|
self::assertSame('$A3', $conditional->getText());
|
|
$conditions = $conditional->getConditions();
|
|
self::assertSame(['NOT(ISERROR(SEARCH($A3,C3)))'], $conditions);
|
|
|
|
$newWizard = Wizard::fromConditional($conditional, $this->range);
|
|
$newWizard->getConditional();
|
|
self::assertEquals($newWizard, $textWizard, 'fromConditional() Failure');
|
|
}
|
|
|
|
public function testTextNotContainsWizardWithText(): void
|
|
{
|
|
$ruleType = Wizard::TEXT_VALUE;
|
|
/** @var Wizard\TextValue $textWizard */
|
|
$textWizard = $this->wizardFactory->newRule($ruleType);
|
|
self::assertInstanceOf(Wizard\TextValue::class, $textWizard);
|
|
|
|
$textWizard->setStyle($this->style);
|
|
$textWizard->doesNotContain('LL');
|
|
|
|
$conditional = $textWizard->getConditional();
|
|
self::assertSame(Conditional::CONDITION_NOTCONTAINSTEXT, $conditional->getConditionType());
|
|
self:self::assertSame(Conditional::OPERATOR_NOTCONTAINS, $conditional->getOperatorType());
|
|
self::assertSame('LL', $conditional->getText());
|
|
$conditions = $conditional->getConditions();
|
|
self::assertSame(['ISERROR(SEARCH("LL",C3))'], $conditions);
|
|
|
|
$newWizard = Wizard::fromConditional($conditional, $this->range);
|
|
$newWizard->getConditional();
|
|
self::assertEquals($newWizard, $textWizard, 'fromConditional() Failure');
|
|
}
|
|
|
|
public function testTextBeginsWithWizardWithText(): void
|
|
{
|
|
$ruleType = Wizard::TEXT_VALUE;
|
|
/** @var Wizard\TextValue $textWizard */
|
|
$textWizard = $this->wizardFactory->newRule($ruleType);
|
|
self::assertInstanceOf(Wizard\TextValue::class, $textWizard);
|
|
|
|
$textWizard->setStyle($this->style);
|
|
$textWizard->beginsWith('LL');
|
|
|
|
$conditional = $textWizard->getConditional();
|
|
self::assertSame(Conditional::CONDITION_BEGINSWITH, $conditional->getConditionType());
|
|
self:self::assertSame(Conditional::OPERATOR_BEGINSWITH, $conditional->getOperatorType());
|
|
self::assertSame('LL', $conditional->getText());
|
|
$conditions = $conditional->getConditions();
|
|
self::assertSame(['LEFT(C3,LEN("LL"))="LL"'], $conditions);
|
|
|
|
$newWizard = Wizard::fromConditional($conditional, $this->range);
|
|
$newWizard->getConditional();
|
|
self::assertEquals($newWizard, $textWizard, 'fromConditional() Failure');
|
|
}
|
|
|
|
public function testTextEndsWithWizardWithText(): void
|
|
{
|
|
$ruleType = Wizard::TEXT_VALUE;
|
|
/** @var Wizard\TextValue $textWizard */
|
|
$textWizard = $this->wizardFactory->newRule($ruleType);
|
|
self::assertInstanceOf(Wizard\TextValue::class, $textWizard);
|
|
|
|
$textWizard->setStyle($this->style);
|
|
$textWizard->endsWith('LL');
|
|
|
|
$conditional = $textWizard->getConditional();
|
|
self::assertSame(Conditional::CONDITION_ENDSWITH, $conditional->getConditionType());
|
|
self:self::assertSame(Conditional::OPERATOR_ENDSWITH, $conditional->getOperatorType());
|
|
$conditions = $conditional->getConditions();
|
|
self::assertSame(['RIGHT(C3,LEN("LL"))="LL"'], $conditions);
|
|
|
|
$newWizard = Wizard::fromConditional($conditional, $this->range);
|
|
$newWizard->getConditional();
|
|
self::assertEquals($newWizard, $textWizard, 'fromConditional() Failure');
|
|
}
|
|
|
|
public function testInvalidFromConditional(): void
|
|
{
|
|
$ruleType = 'Unknown';
|
|
$this->expectException(Exception::class);
|
|
$this->expectExceptionMessage('Conditional is not a Text Value CF Rule conditional');
|
|
|
|
$conditional = new Conditional();
|
|
$conditional->setConditionType($ruleType);
|
|
Wizard\TextValue::fromConditional($conditional);
|
|
}
|
|
}
|