Skip to content

Commit

Permalink
ENGCOM-4242: [ForwardPort] magento#18896 Add Mexico Regions magento#2…
Browse files Browse the repository at this point in the history
  • Loading branch information
sidolov authored Mar 15, 2019
2 parents 769604a + 482dda5 commit a9d69c4
Show file tree
Hide file tree
Showing 4 changed files with 162 additions and 12 deletions.
13 changes: 6 additions & 7 deletions app/code/Magento/Directory/Setup/Patch/Data/AddDataForIndia.php
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,7 @@
use Magento\Framework\Setup\Patch\PatchVersionInterface;

/**
* Class AddDataForIndia
* @package Magento\Directory\Setup\Patch\Data
* Add Regions for India.
*/
class AddDataForIndia implements DataPatchInterface, PatchVersionInterface
{
Expand All @@ -29,7 +28,7 @@ class AddDataForIndia implements DataPatchInterface, PatchVersionInterface
private $dataInstallerFactory;

/**
* AddDataForCroatia constructor.
* AddDataForIndia constructor.
*
* @param ModuleDataSetupInterface $moduleDataSetup
* @param \Magento\Directory\Setup\DataInstallerFactory $dataInstallerFactory
Expand All @@ -43,7 +42,7 @@ public function __construct(
}

/**
* {@inheritdoc}
* @inheritdoc
*/
public function apply()
{
Expand Down Expand Up @@ -103,7 +102,7 @@ private function getDataForIndia()
}

/**
* {@inheritdoc}
* @inheritdoc
*/
public static function getDependencies()
{
Expand All @@ -113,15 +112,15 @@ public static function getDependencies()
}

/**
* {@inheritdoc}
* @inheritdoc
*/
public static function getVersion()
{
return '2.0.2';
}

/**
* {@inheritdoc}
* @inheritdoc
*/
public function getAliases()
{
Expand Down
127 changes: 127 additions & 0 deletions app/code/Magento/Directory/Setup/Patch/Data/AddDataForMexico.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,127 @@
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/

declare(strict_types=1);

namespace Magento\Directory\Setup\Patch\Data;

use Magento\Directory\Setup\DataInstaller;
use Magento\Framework\Setup\ModuleDataSetupInterface;
use Magento\Framework\Setup\Patch\DataPatchInterface;
use Magento\Framework\Setup\Patch\PatchVersionInterface;

/**
* Adds Mexican States
*/
class AddDataForMexico implements DataPatchInterface, PatchVersionInterface
{
/**
* @var ModuleDataSetupInterface
*/
private $moduleDataSetup;

/**
* @var \Magento\Directory\Setup\DataInstallerFactory
*/
private $dataInstallerFactory;

/**
* @param ModuleDataSetupInterface $moduleDataSetup
* @param \Magento\Directory\Setup\DataInstallerFactory $dataInstallerFactory
*/
public function __construct(
ModuleDataSetupInterface $moduleDataSetup,
\Magento\Directory\Setup\DataInstallerFactory $dataInstallerFactory
) {
$this->moduleDataSetup = $moduleDataSetup;
$this->dataInstallerFactory = $dataInstallerFactory;
}

/**
* @inheritdoc
*/
public function apply()
{
/** @var DataInstaller $dataInstaller */
$dataInstaller = $this->dataInstallerFactory->create();
$dataInstaller->addCountryRegions(
$this->moduleDataSetup->getConnection(),
$this->getDataForMexico()
);
}

/**
* Mexican states data.
*
* @return array
*/
private function getDataForMexico()
{
return [
['MX', 'AGU', 'Aguascalientes'],
['MX', 'BCN', 'Baja California'],
['MX', 'BCS', 'Baja California Sur'],
['MX', 'CAM', 'Campeche'],
['MX', 'CHP', 'Chiapas'],
['MX', 'CHH', 'Chihuahua'],
['MX', 'CMX', 'Ciudad de México'],
['MX', 'COA', 'Coahuila'],
['MX', 'COL', 'Colima'],
['MX', 'DUR', 'Durango'],
['MX', 'MEX', 'Estado de México'],
['MX', 'GUA', 'Guanajuato'],
['MX', 'GRO', 'Guerrero'],
['MX', 'HID', 'Hidalgo'],
['MX', 'JAL', 'Jalisco'],
['MX', 'MIC', 'Michoacán'],
['MX', 'MOR', 'Morelos'],
['MX', 'NAY', 'Nayarit'],
['MX', 'NLE', 'Nuevo León'],
['MX', 'OAX', 'Oaxaca'],
['MX', 'PUE', 'Puebla'],
['MX', 'QUE', 'Querétaro'],
['MX', 'ROO', 'Quintana Roo'],
['MX', 'SLP', 'San Luis Potosí'],
['MX', 'SIN', 'Sinaloa'],
['MX', 'SON', 'Sonora'],
['MX', 'TAB', 'Tabasco'],
['MX', 'TAM', 'Tamaulipas'],
['MX', 'TLA', 'Tlaxcala'],
['MX', 'VER', 'Veracruz'],
['MX', 'YUC', 'Yucatán'],
['MX', 'ZAC', 'Zacatecas']
];
}

/**
* @inheritdoc
*/
public static function getDependencies()
{
return [
InitializeDirectoryData::class,
AddDataForAustralia::class,
AddDataForCroatia::class,
AddDataForIndia::class,
];
}

/**
* @inheritdoc
*/
public static function getVersion()
{
return '2.0.4';
}

/**
* @inheritdoc
*/
public function getAliases()
{
return [];
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -265,7 +265,7 @@ protected function addSingleCondition($condition, ElementInterface $context)
$this->addCondition($condition['type'], $context);
$createdCondition = $context->find($this->created, Locator::SELECTOR_XPATH);
$this->waitForCondition($createdCondition);
$this->fillCondition($condition['rules'], $createdCondition);
$this->fillCondition($condition['rules'], $createdCondition, $condition['type']);
}

/**
Expand Down Expand Up @@ -306,13 +306,14 @@ protected function addCondition($type, ElementInterface $context)
*
* @param array $rules
* @param ElementInterface $element
* @param string|null $type
* @return void
* @throws \Exception
*
* @SuppressWarnings(PHPMD.CyclomaticComplexity)
* @SuppressWarnings(PHPMD.NPathComplexity)
*/
protected function fillCondition(array $rules, ElementInterface $element)
protected function fillCondition(array $rules, ElementInterface $element, $type = null)
{
$this->resetKeyParam();
foreach ($rules as $rule) {
Expand All @@ -333,7 +334,7 @@ protected function fillCondition(array $rules, ElementInterface $element)

if ($this->fillGrid($rule, $param)) {
$isSet = true;
} elseif ($this->fillSelect($rule, $param)) {
} elseif ($this->fillSelect($rule, $param, $type)) {
$isSet = true;
} elseif ($this->fillText($rule, $param)) {
$isSet = true;
Expand Down Expand Up @@ -390,11 +391,15 @@ protected function fillGrid($rule, ElementInterface $param)
*
* @param string $rule
* @param ElementInterface $param
* @param string|null $type
* @return bool
*/
protected function fillSelect($rule, ElementInterface $param)
protected function fillSelect($rule, ElementInterface $param, $type = null)
{
$value = $param->find('select', Locator::SELECTOR_TAG_NAME, 'select');
//Avoid confusion between regions like: "Baja California" and "California".
$value = strpos($type, 'State/Province') === false
? $param->find('select', Locator::SELECTOR_TAG_NAME, 'select')
: $param->find('select', Locator::SELECTOR_TAG_NAME, 'selectstate');
if ($value->isVisible()) {
$value->setValue($rule);
$this->click();
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);

namespace Magento\Mtf\Client\Element;

/**
* @inheritdoc
*/
class SelectstateElement extends SelectElement
{
/**
* @inheritdoc
*/
protected $optionByValue = './/option[normalize-space(.)=%s]';
}

0 comments on commit a9d69c4

Please sign in to comment.