From e9a1527e3eb28673a9d6476ec681ca0b60fe9ef8 Mon Sep 17 00:00:00 2001 From: Brian Weaver <weaver.299@osu.edu> Date: Tue, 21 Jan 2020 14:34:01 -0500 Subject: [PATCH] Update 'simple_gmap' module -- 1.4 --> 2.0 --- composer.json | 2 +- composer.lock | 25 ++- vendor/composer/installed.json | 25 ++- .../config/schema/simple_gmap.schema.yml | 3 + web/modules/simple_gmap/simple_gmap.info.yml | 12 +- web/modules/simple_gmap/simple_gmap.module | 1 + .../FieldFormatter/SimpleGMapFormatter.php | 55 +++-- .../simple_gmap/src/Tests/SimpleGmapTest.php | 196 ------------------ .../templates/simple-gmap-output.html.twig | 3 +- ...y.node.simple_gmap_stress_test.default.yml | 93 +++++++++ ...y.node.simple_gmap_stress_test.default.yml | 100 +++++++++ ...ay.node.simple_gmap_stress_test.teaser.yml | 26 +++ ...de.simple_gmap_stress_test.field_blank.yml | 19 ++ ...ode.simple_gmap_stress_test.field_map1.yml | 21 ++ ...ode.simple_gmap_stress_test.field_map2.yml | 21 ++ ...node.simple_gmap_stress_test.field_xss.yml | 21 ++ .../field.storage.node.field_blank.yml | 21 ++ .../install/field.storage.node.field_map1.yml | 21 ++ .../install/field.storage.node.field_map2.yml | 21 ++ .../install/field.storage.node.field_xss.yml | 21 ++ .../node.type.simple_gmap_stress_test.yml | 10 + .../simple_gmap_stress_test.info.yml | 13 ++ .../stress_test.info.yml | 12 ++ .../FunctionalJavascript/SimpleGmapTest.php | 140 +++++++++++++ .../src/Kernel/SimpleGMapFormatterTest.php | 76 +++++++ 25 files changed, 716 insertions(+), 242 deletions(-) delete mode 100644 web/modules/simple_gmap/src/Tests/SimpleGmapTest.php create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_form_display.node.simple_gmap_stress_test.default.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_view_display.node.simple_gmap_stress_test.default.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_view_display.node.simple_gmap_stress_test.teaser.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_blank.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_map1.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_map2.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_xss.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_blank.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_map1.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_map2.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_xss.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/node.type.simple_gmap_stress_test.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/simple_gmap_stress_test.info.yml create mode 100644 web/modules/simple_gmap/tests/module/simple_gmap_stress_test/stress_test.info.yml create mode 100644 web/modules/simple_gmap/tests/src/FunctionalJavascript/SimpleGmapTest.php create mode 100644 web/modules/simple_gmap/tests/src/Kernel/SimpleGMapFormatterTest.php diff --git a/composer.json b/composer.json index d2d53683c1..ec50d64342 100644 --- a/composer.json +++ b/composer.json @@ -162,7 +162,7 @@ "drupal/scheduler": "1.0", "drupal/search_api": "1.1", "drupal/search_api_db": "1.1", - "drupal/simple_gmap": "^1.4", + "drupal/simple_gmap": "^2.0", "drupal/simple_megamenu": "1.0-beta3", "drupal/simple_sitemap": "^3.0", "drupal/simplesamlphp_auth": "3.1", diff --git a/composer.lock b/composer.lock index 6e0c39b63c..4c6822df3a 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "9a04dacb71a790084b49b56a9b48608e", + "content-hash": "0152be0b23fe32d326005f2420b7c6a8", "packages": [ { "name": "alchemy/zippy", @@ -7056,29 +7056,32 @@ }, { "name": "drupal/simple_gmap", - "version": "1.4.0", + "version": "2.0.0", "source": { "type": "git", "url": "https://git.drupalcode.org/project/simple_gmap.git", - "reference": "8.x-1.4" + "reference": "8.x-2.0" }, "dist": { "type": "zip", - "url": "https://ftp.drupal.org/files/projects/simple_gmap-8.x-1.4.zip", - "reference": "8.x-1.4", - "shasum": "364d59f318052ab8094b25e52b43f7f7deda9259" + "url": "https://ftp.drupal.org/files/projects/simple_gmap-8.x-2.0.zip", + "reference": "8.x-2.0", + "shasum": "d218842c311795cded1a75bc93595e95a9e5d701" }, "require": { - "drupal/core": "*" + "drupal/core": "^8 || ^9" + }, + "require-dev": { + "drupal/address": "*" }, "type": "drupal-module", "extra": { "branch-alias": { - "dev-1.x": "1.x-dev" + "dev-2.x": "2.x-dev" }, "drupal": { - "version": "8.x-1.4", - "datestamp": "1504630143", + "version": "8.x-2.0", + "datestamp": "1579517588", "security-coverage": { "status": "covered", "message": "Covered by Drupal's security advisory policy" @@ -7102,7 +7105,7 @@ "description": "Provides a Google Maps link/map formatter for simple Text fields.", "homepage": "https://www.drupal.org/project/simple_gmap", "support": { - "source": "http://cgit.drupalcode.org/simple_gmap" + "source": "https://git.drupalcode.org/project/simple_gmap" } }, { diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json index d9497cafee..4efb47c236 100644 --- a/vendor/composer/installed.json +++ b/vendor/composer/installed.json @@ -7276,30 +7276,33 @@ }, { "name": "drupal/simple_gmap", - "version": "1.4.0", - "version_normalized": "1.4.0.0", + "version": "2.0.0", + "version_normalized": "2.0.0.0", "source": { "type": "git", "url": "https://git.drupalcode.org/project/simple_gmap.git", - "reference": "8.x-1.4" + "reference": "8.x-2.0" }, "dist": { "type": "zip", - "url": "https://ftp.drupal.org/files/projects/simple_gmap-8.x-1.4.zip", - "reference": "8.x-1.4", - "shasum": "364d59f318052ab8094b25e52b43f7f7deda9259" + "url": "https://ftp.drupal.org/files/projects/simple_gmap-8.x-2.0.zip", + "reference": "8.x-2.0", + "shasum": "d218842c311795cded1a75bc93595e95a9e5d701" }, "require": { - "drupal/core": "*" + "drupal/core": "^8 || ^9" + }, + "require-dev": { + "drupal/address": "*" }, "type": "drupal-module", "extra": { "branch-alias": { - "dev-1.x": "1.x-dev" + "dev-2.x": "2.x-dev" }, "drupal": { - "version": "8.x-1.4", - "datestamp": "1504630143", + "version": "8.x-2.0", + "datestamp": "1579517588", "security-coverage": { "status": "covered", "message": "Covered by Drupal's security advisory policy" @@ -7324,7 +7327,7 @@ "description": "Provides a Google Maps link/map formatter for simple Text fields.", "homepage": "https://www.drupal.org/project/simple_gmap", "support": { - "source": "http://cgit.drupalcode.org/simple_gmap" + "source": "https://git.drupalcode.org/project/simple_gmap" } }, { diff --git a/web/modules/simple_gmap/config/schema/simple_gmap.schema.yml b/web/modules/simple_gmap/config/schema/simple_gmap.schema.yml index f7df98a173..40c65b0b96 100644 --- a/web/modules/simple_gmap/config/schema/simple_gmap.schema.yml +++ b/web/modules/simple_gmap/config/schema/simple_gmap.schema.yml @@ -20,6 +20,9 @@ field.formatter.settings.simple_gmap: iframe_width: type: string label: 'Width of embedded map' + iframe_title: + type: string + label: 'A title for describing the iframe for accessibility reasons' static_scale: type: integer label: 'Whether to scale static map image for retina displays' diff --git a/web/modules/simple_gmap/simple_gmap.info.yml b/web/modules/simple_gmap/simple_gmap.info.yml index 40a01ecb1b..75589b0f00 100644 --- a/web/modules/simple_gmap/simple_gmap.info.yml +++ b/web/modules/simple_gmap/simple_gmap.info.yml @@ -2,13 +2,15 @@ name: 'Simple Google Maps' type: module description: 'Provides a Google Maps link/map formatter for simple Text fields.' package: Field types -# core: 8.x +core: 8.x +core_version_requirement: ^8 || ^9 dependencies: - field - text +test_dependencies: + - address -# Information added by Drupal.org packaging script on 2017-09-05 -version: '8.x-1.4' -core: '8.x' +# Information added by Drupal.org packaging script on 2020-01-20 +version: '8.x-2.0' project: 'simple_gmap' -datestamp: 1504630147 +datestamp: 1579517590 diff --git a/web/modules/simple_gmap/simple_gmap.module b/web/modules/simple_gmap/simple_gmap.module index 8ac48c115a..d2877e7a3a 100644 --- a/web/modules/simple_gmap/simple_gmap.module +++ b/web/modules/simple_gmap/simple_gmap.module @@ -31,6 +31,7 @@ function simple_gmap_theme() { 'langcode' => NULL, 'static_map_type' => NULL, 'apikey' => NULL, + 'iframe_title' => '', ], 'template' => 'simple-gmap-output', ], diff --git a/web/modules/simple_gmap/src/Plugin/Field/FieldFormatter/SimpleGMapFormatter.php b/web/modules/simple_gmap/src/Plugin/Field/FieldFormatter/SimpleGMapFormatter.php index 184e12d43e..b67e33aab4 100644 --- a/web/modules/simple_gmap/src/Plugin/Field/FieldFormatter/SimpleGMapFormatter.php +++ b/web/modules/simple_gmap/src/Plugin/Field/FieldFormatter/SimpleGMapFormatter.php @@ -26,12 +26,13 @@ class SimpleGMapFormatter extends FormatterBase { */ public static function defaultSettings() { return [ - "include_map" => "1", - "include_static_map" => "0", - "include_link" => "0", - "include_text" => "0", + "include_map" => TRUE, + "include_static_map" => FALSE, + "include_link" => FALSE, + "include_text" => FALSE, "iframe_height" => "200", "iframe_width" => "200", + "iframe_title" => "", "static_scale" => 1, "zoom_level" => "14", "link_text" => "View larger map", @@ -68,6 +69,9 @@ public function settingsForm(array $form, FormStateInterface $form_state) { '#description' => $this->t('Static Maps will not work without an API key. See the <a href="https://developers.google.com/maps/documentation/static-maps" target="_blank">Static Maps API page</a> to learn more and obtain a key.'), '#states' => [ 'visible' => [ + ":input[name*='include_static_map']" => ['checked' => TRUE], + ], + 'required' => [ ':input[name*="include_static_map"]' => ['checked' => TRUE], ], ], @@ -86,6 +90,12 @@ public function settingsForm(array $form, FormStateInterface $form_state) { '#description' => $this->t('You can set sizes in px or percent (ex: 600px or 100%). Note that static maps only accept sizes in pixels, without the suffix px (ex: 600).'), '#size' => 10, ]; + $elements['iframe_title'] = [ + '#type' => 'textfield', + '#title' => $this->t('Title of the iframe for embedded map'), + '#default_value' => $this->getSetting('iframe_title'), + '#description' => $this->t('The embedded map is in an iframe HTML tag, which should have a title attribute for screen readers (not shown on the page). Use [address] to insert the address text in the title.'), + ]; $elements['static_scale'] = [ '#title' => $this->t('Load Retina sized static image'), '#type' => 'select', @@ -185,8 +195,15 @@ public function settingsSummary() { $include_map = $this->getSetting('include_map'); if ($include_map) { - $summary[] = $this->t('Dynamic map: @width x @height', ['@width' => $this->getSetting('iframe_width'), '@height' => $this->getSetting('iframe_height')]); + $summary[] = $this->t('Dynamic map: @width x @height', [ + '@width' => $this->getSetting('iframe_width'), + '@height' => $this->getSetting('iframe_height'), + ]); + $summary[] = $this->t('Title of the iframe: @title', [ + '@title' => $this->getSetting('iframe_title'), + ]); } + $include_static_map = $this->getSetting('include_static_map'); if ($include_static_map) { $summary[] = $this->t('Static map: @width x @height, Scale: @static_scale', [ @@ -195,9 +212,12 @@ public function settingsSummary() { '@static_scale' => $this->getSetting('static_scale'), ]); } + $include_link = $this->getSetting('include_link'); if ($include_link) { - $summary[] = $this->t('Map link: @link_text', ['@link_text' => $this->getSetting('link_text')]); + $summary[] = $this->t('Map link: @link_text', [ + '@link_text' => $this->getSetting('link_text'), + ]); } if ($include_link || $include_map || $include_static_map) { @@ -217,15 +237,10 @@ public function settingsSummary() { * {@inheritdoc} */ public function viewElements(FieldItemListInterface $items, $langcode) { - $element = []; $settings = $this->getSettings(); - $embed = (int) $settings['include_map'] ? TRUE : FALSE; - $static = (int) $settings['include_static_map'] ? TRUE : FALSE; - $link = (int) $settings['include_link'] ? TRUE : FALSE; - $text = (int) $settings['include_text'] ? TRUE : FALSE; - + $include_text = $settings['include_text']; $zoom_level = (int) $settings['zoom_level']; // For some reason, static gmaps accepts a different value for map type. @@ -249,18 +264,23 @@ public function viewElements(FieldItemListInterface $items, $langcode) { foreach ($items as $delta => $item) { $url_value = urlencode($item->value); $address_value = $item->value; - $address = $text ? $address_value : ''; + $address = $include_text ? $address_value : ''; $text_for_link = ($settings['link_text'] == 'use_address') ? $address_value : $settings['link_text']; $link_text = ['#plain_text' => $text_for_link]; + $iframe_title = $settings['iframe_title']; + $iframe_title_value = [ + '#plain_text' => str_replace('[address]', $address_value, $iframe_title), + ]; $element[$delta] = [ '#theme' => 'simple_gmap_output', - '#include_map' => $embed, - '#include_static_map' => $static, - '#include_link' => $link, - '#include_text' => $text, + '#include_map' => $settings['include_map'], + '#include_static_map' => $settings['include_static_map'], + '#include_link' => $settings['include_link'], + '#include_text' => $settings['include_text'], '#width' => ['#plain_text' => $settings['iframe_width']], '#height' => ['#plain_text' => $settings['iframe_height']], + '#iframe_title' => $iframe_title_value, '#static_scale' => (int) $settings['static_scale'], '#url_suffix' => $url_value, '#zoom' => $zoom_level, @@ -272,6 +292,7 @@ public function viewElements(FieldItemListInterface $items, $langcode) { '#apikey' => $settings['apikey'], ]; } + return $element; } diff --git a/web/modules/simple_gmap/src/Tests/SimpleGmapTest.php b/web/modules/simple_gmap/src/Tests/SimpleGmapTest.php deleted file mode 100644 index 11e9170369..0000000000 --- a/web/modules/simple_gmap/src/Tests/SimpleGmapTest.php +++ /dev/null @@ -1,196 +0,0 @@ -<?php - -namespace Drupal\simple_gmap\Tests; - -use Drupal\simpletest\WebTestBase; - -/** - * Creates a page to look at to test the Simple Google Maps module. - * - * Run the test, scroll to the bottom, open the last page link, and check - * what the verbose message lines say to check on that page. If you want to - * check the static maps, be sure to edit this file and put in an API key - * that is valid for static maps. - * - * @group simple_gmap - */ -class SimpleGmapTest extends WebTestBase { - - /** - * API key for static maps. - * - * @var string - */ - protected $apiKey = 'Static maps will not work unless you put in a key'; - - /** - * Modules to enable. - * - * @var array - */ - public static $modules = [ - 'simple_gmap', - 'node', - 'field', - 'field_ui', - 'text', - 'block', - 'user', - ]; - - /** - * {@inheritdoc} - */ - protected function setUp() { - parent::setUp(); - - $this->drupalCreateContentType(['type' => 'article']); - drupal_static_reset(); - \Drupal::entityManager()->clearCachedDefinitions(); - \Drupal::service('router.builder')->rebuild(); - \Drupal::service('entity.definition_update_manager')->applyUpdates(); - - $admin_user = $this->drupalCreateUser([ - 'bypass node access', - 'administer content types', - 'administer node fields', - 'administer node display', - 'create article content', - ]); - $this->drupalLogin($admin_user); - - // Make sure local tasks and page title are showing. - $this->drupalPlaceBlock('local_tasks_block'); - $this->drupalPlaceBlock('page_title_block'); - } - - /** - * Creates the test pages. - */ - public function testModule() { - $field1 = 'map1'; - $field2 = 'map2'; - $field3 = 'xss'; - - $address1 = 'Eiffel Tower'; - $address2 = "Place de l'Université-du-Québec, boulevard Charest Est, Québec, QC G1K"; - $address2entities = "Place de l'Université-du-Québec, boulevard Charest Est, Québec, QC G1K"; - $address3 = '<script>alert("hello");</script> Empire State Building'; - - // Add three text fields to the Article content type. - $this->drupalGet('admin/structure/types/manage/article/fields/add-field'); - $this->drupalPostForm(NULL, [ - 'new_storage_type' => 'string', - ], 'Save and continue'); - // This opens up the page again with field errors for name and label. - $this->drupalPostForm(NULL, [ - 'label' => $field1, - 'field_name' => $field1, - ], 'Save and continue'); - $this->drupalPostForm(NULL, [], 'Save field settings'); - $this->drupalPostForm(NULL, [], 'Save settings'); - - $this->drupalGet('admin/structure/types/manage/article/fields/add-field'); - $this->drupalPostForm(NULL, [ - 'new_storage_type' => 'string', - ], 'Save and continue'); - $this->drupalPostForm(NULL, [ - 'label' => $field2, - 'field_name' => $field2, - ], 'Save and continue'); - $this->drupalPostForm(NULL, [], 'Save field settings'); - $this->drupalPostForm(NULL, [], 'Save settings'); - - $this->drupalGet('admin/structure/types/manage/article/fields/add-field'); - $this->drupalPostForm(NULL, [ - 'new_storage_type' => 'string', - ], 'Save and continue'); - $this->drupalPostForm(NULL, [ - 'label' => $field3, - 'field_name' => $field3, - ], 'Save and continue'); - $this->drupalPostForm(NULL, [], 'Save field settings'); - $this->drupalPostForm(NULL, [], 'Save settings'); - - // Set the formatter for all of the fields. - $this->drupalGet('admin/structure/types/manage/article/display'); - $this->assertRaw('Google Map from one-line address'); - $this->drupalPostForm(NULL, [ - 'fields[field_' . $field1 . '][type]' => 'simple_gmap', - 'fields[field_' . $field2 . '][type]' => 'simple_gmap', - 'fields[field_' . $field3 . '][type]' => 'simple_gmap', - ], 'Save'); - - // Change the settings for all field formatters. - $this->drupalPostAjaxForm(NULL, [], 'field_' . $field1 . '_settings_edit'); - $prefix = 'fields[field_' . $field1 . '][settings_edit_form][settings]'; - $this->drupalPostForm(NULL, [ - $prefix . '[include_map]' => TRUE, - $prefix . '[include_static_map]' => TRUE, - $prefix . '[apikey]' => $this->apiKey, - $prefix . '[include_link]' => TRUE, - $prefix . '[include_text]' => TRUE, - ], 'Update'); - $this->assertText('Map link: View larger map'); - $this->assertText('Zoom Level: 14'); - $this->assertText('Language: en'); - $this->assertText('Map Type: Map'); - $this->assertText('Dynamic map'); - $this->assertText('Static map'); - $this->assertText('Original text displayed'); - - $this->drupalPostAjaxForm(NULL, [], 'field_' . $field2 . '_settings_edit'); - $prefix = 'fields[field_' . $field2 . '][settings_edit_form][settings]'; - $this->drupalPostForm(NULL, [ - $prefix . '[include_map]' => TRUE, - $prefix . '[include_static_map]' => TRUE, - $prefix . '[apikey]' => $this->apiKey, - $prefix . '[include_link]' => TRUE, - $prefix . '[link_text]' => 'use_address', - $prefix . '[include_text]' => TRUE, - $prefix . '[zoom_level]' => 5, - $prefix . '[map_type]' => 'k', - $prefix . '[langcode]' => 'page', - ], 'Update'); - $this->assertText('Map link: use_address'); - $this->assertText('Zoom Level: 5'); - $this->assertText('Language: page'); - $this->assertText('Map Type: Satellite'); - - $this->drupalPostAjaxForm(NULL, [], 'field_' . $field3 . '_settings_edit'); - $prefix = 'fields[field_' . $field3 . '][settings_edit_form][settings]'; - $this->drupalPostForm(NULL, [ - $prefix . '[include_map]' => TRUE, - $prefix . '[include_static_map]' => TRUE, - $prefix . '[apikey]' => $this->apiKey, - $prefix . '[include_link]' => TRUE, - $prefix . '[include_text]' => TRUE, - ], 'Update'); - - // Save all the settings. - $this->drupalPostForm(NULL, [], 'Save'); - - // Create an article with three addresses. - $this->drupalGet('node/add/article'); - $this->drupalPostForm(NULL, [ - 'title[0][value]' => 'Map test', - 'field_' . $field1 . '[0][value]' => $address1, - 'field_' . $field2 . '[0][value]' => $address2, - 'field_' . $field3 . '[0][value]' => $address3, - ], 'Save'); - - $this->pass('Open the previous link. In the first field, verify: (1) Both the static and dynamic maps are displayed. (2) The link to the larger map is included, with text "View larger map". (3) If you click the map link, the larger map is shown and "Eiffel Tower" appears in the address box. (4) The text "Eiffel Tower" appears below the maps and link.'); - $this->pass("In the second field, verify: (1) Both the static and dynamic maps are displayed. (2) They should be zoomed way out to the regional level, rather than street level. (3) They should be satellite images rather than street maps. (4) The link to the larger map is included, but the link text is \"Place de l'Université-du-Québec, boulevard Charest Est, Québec, QC G1K\". (5) Verify that the map link has &hl=en in it (so it picked up the page language). (6) If you click the map link, the larger map is shown and \"Place de l'Université-du-Québec, boulevard Charest Est, Québec, QC G1K\" appears in the address box. (7) The text \"Place de l'Université-du-Québec, boulevard Charest Est, Québec, QC G1K\" appears below the maps and link."); - $this->pass("The third field is a XSS test. Verify that the script tags are shown rather than being processed by the browser. Maps will likely show the entire world as it is not a valid address. There should not be a JavaScript alert box shown."); - - $this->assertLink('View larger map'); - // Looking for this link isn't working, with or without the - // entities. Will need to be a manual test. - // $this->assertLink($address2entities); - $this->assertText($address1); - $this->assertText($address2entities); - $this->assertText(htmlentities($address3)); - $this->assertRaw('google.com/maps'); - } - -} diff --git a/web/modules/simple_gmap/templates/simple-gmap-output.html.twig b/web/modules/simple_gmap/templates/simple-gmap-output.html.twig index 930618817a..0bb551b8bb 100644 --- a/web/modules/simple_gmap/templates/simple-gmap-output.html.twig +++ b/web/modules/simple_gmap/templates/simple-gmap-output.html.twig @@ -22,12 +22,13 @@ * - static_map_type: Type of map to use for static map (Google code, such as * 'roadmap' or 'satellite') * - apikey: Google Maps API key (used for static maps only). + * - title: A title attribute for the iframe * * @ingroup themeable */ #} {% if include_map %} - <iframe width="{{ width }}" height="{{ height }}" frameborder="0" style="border:0" src="https://maps.google.com/maps?hl={{ langcode }}&q={{ url_suffix }}&t={{ map_type }}&z={{ zoom }}&output=embed"></iframe> + <iframe width="{{ width }}" height="{{ height }}" title="{{ iframe_title }}" frameborder="0" style="border:0" src="https://maps.google.com/maps?hl={{ langcode }}&q={{ url_suffix }}&t={{ map_type }}&z={{ zoom }}&output=embed"></iframe> {% endif %} {% if include_static_map %} <div class="simple-gmap-static-map"> diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_form_display.node.simple_gmap_stress_test.default.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_form_display.node.simple_gmap_stress_test.default.yml new file mode 100644 index 0000000000..e3409000cc --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_form_display.node.simple_gmap_stress_test.default.yml @@ -0,0 +1,93 @@ +uuid: acdfe773-c815-454d-b520-bbdf5a7ed473 +langcode: en +status: true +dependencies: + config: + - field.field.node.simple_gmap_stress_test.field_blank + - field.field.node.simple_gmap_stress_test.field_map1 + - field.field.node.simple_gmap_stress_test.field_map2 + - field.field.node.simple_gmap_stress_test.field_xss + - node.type.simple_gmap_stress_test +id: node.simple_gmap_stress_test.default +targetEntityType: node +bundle: simple_gmap_stress_test +mode: default +content: + created: + type: datetime_timestamp + weight: 10 + region: content + settings: { } + third_party_settings: { } + field_blank: + weight: 124 + settings: + size: 60 + placeholder: '' + third_party_settings: { } + type: string_textfield + region: content + field_map1: + weight: 121 + settings: + size: 60 + placeholder: '' + third_party_settings: { } + type: string_textfield + region: content + field_map2: + weight: 122 + settings: + size: 60 + placeholder: '' + third_party_settings: { } + type: string_textfield + region: content + field_xss: + weight: 123 + settings: + size: 60 + placeholder: '' + third_party_settings: { } + type: string_textfield + region: content + promote: + type: boolean_checkbox + settings: + display_label: true + weight: 15 + region: content + third_party_settings: { } + status: + type: boolean_checkbox + settings: + display_label: true + weight: 120 + region: content + third_party_settings: { } + sticky: + type: boolean_checkbox + settings: + display_label: true + weight: 16 + region: content + third_party_settings: { } + title: + type: string_textfield + weight: -5 + region: content + settings: + size: 60 + placeholder: '' + third_party_settings: { } + uid: + type: entity_reference_autocomplete + weight: 5 + settings: + match_operator: CONTAINS + match_limit: 10 + size: 60 + placeholder: '' + region: content + third_party_settings: { } +hidden: { } diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_view_display.node.simple_gmap_stress_test.default.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_view_display.node.simple_gmap_stress_test.default.yml new file mode 100644 index 0000000000..cc7a621572 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_view_display.node.simple_gmap_stress_test.default.yml @@ -0,0 +1,100 @@ +uuid: 56138ea6-7df8-445f-8fe9-44b86e65e71e +langcode: en +status: true +dependencies: + config: + - field.field.node.simple_gmap_stress_test.field_blank + - field.field.node.simple_gmap_stress_test.field_map1 + - field.field.node.simple_gmap_stress_test.field_map2 + - field.field.node.simple_gmap_stress_test.field_xss + - node.type.simple_gmap_stress_test + module: + - simple_gmap + - user +id: node.simple_gmap_stress_test.default +targetEntityType: node +bundle: simple_gmap_stress_test +mode: default +content: + field_blank: + weight: 104 + label: above + settings: + include_map: true + include_static_map: false + include_link: false + include_text: false + iframe_height: '200' + iframe_width: '200' + static_scale: 1 + zoom_level: 14 + link_text: 'View larger map' + map_type: m + langcode: en + apikey: '' + third_party_settings: { } + type: simple_gmap + region: content + field_map1: + weight: 101 + label: above + settings: + include_map: true + include_static_map: true + apikey: 'Static maps will not work unless you put in a key' + iframe_width: '200' + iframe_height: '200' + static_scale: 1 + link_text: 'use_address' + zoom_level: 14 + map_type: m + langcode: en + include_link: true + include_text: true + third_party_settings: { } + type: simple_gmap + region: content + field_map2: + weight: 102 + label: above + settings: + include_map: true + include_static_map: true + apikey: 'Static maps will not work unless you put in a key' + iframe_width: '200' + iframe_height: '200' + static_scale: 1 + link_text: 'View larger map' + zoom_level: 5 + include_text: true + map_type: k + langcode: en + include_link: false + third_party_settings: { } + type: simple_gmap + region: content + field_xss: + weight: 103 + label: above + settings: + include_map: true + include_static_map: true + apikey: '' + iframe_width: '200' + iframe_height: '200' + static_scale: 1 + include_link: true + link_text: 'View larger map' + zoom_level: 14 + map_type: m + langcode: en + include_text: true + third_party_settings: { } + type: simple_gmap + region: content + links: + weight: 100 + region: content + settings: { } + third_party_settings: { } +hidden: { } diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_view_display.node.simple_gmap_stress_test.teaser.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_view_display.node.simple_gmap_stress_test.teaser.yml new file mode 100644 index 0000000000..deddc79dcd --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/core.entity_view_display.node.simple_gmap_stress_test.teaser.yml @@ -0,0 +1,26 @@ +uuid: f5d4434b-9f05-402c-8a8a-a7eb0f10b4d8 +langcode: en +status: true +dependencies: + config: + - core.entity_view_mode.node.teaser + - field.field.node.simple_gmap_stress_test.field_map1 + - field.field.node.simple_gmap_stress_test.field_map2 + - field.field.node.simple_gmap_stress_test.field_xss + - field.field.node.simple_gmap_stress_test.field_blank + - node.type.simple_gmap_stress_test + module: + - user +id: node.simple_gmap_stress_test.teaser +targetEntityType: node +bundle: simple_gmap_stress_test +mode: teaser +content: + links: + weight: 100 + region: content +hidden: + field_map1: true + field_map2: true + field_xss: true + field_blank: true diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_blank.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_blank.yml new file mode 100644 index 0000000000..03183bb90e --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_blank.yml @@ -0,0 +1,19 @@ +uuid: fd3bf43d-992f-4e33-9eb5-0499ae0fb47a +langcode: en +status: true +dependencies: + config: + - field.storage.node.field_blank + - node.type.simple_gmap_stress_test +id: node.simple_gmap_stress_test.field_blank +field_name: field_blank +entity_type: node +bundle: simple_gmap_stress_test +label: blank +description: 'A blank field - which tests populate to demonstrate the operation of the formatter''s setting form.' +required: false +translatable: false +default_value: { } +default_value_callback: '' +settings: { } +field_type: string diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_map1.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_map1.yml new file mode 100644 index 0000000000..3fd28d6c56 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_map1.yml @@ -0,0 +1,21 @@ +uuid: 74825356-64da-4f38-8ebd-3451e09cb2d3 +langcode: en +status: true +dependencies: + config: + - field.storage.node.field_map1 + - node.type.simple_gmap_stress_test +id: node.simple_gmap_stress_test.field_map1 +field_name: field_map1 +entity_type: node +bundle: simple_gmap_stress_test +label: map1 +description: 'Expect to see a location in Paris.' +required: true +translatable: false +default_value: + - + value: 'Eiffel Tower' +default_value_callback: '' +settings: { } +field_type: string diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_map2.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_map2.yml new file mode 100644 index 0000000000..488bc59346 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_map2.yml @@ -0,0 +1,21 @@ +uuid: 9ec89da2-070b-4bdf-9c3d-72a603d89e5b +langcode: en +status: true +dependencies: + config: + - field.storage.node.field_map2 + - node.type.simple_gmap_stress_test +id: node.simple_gmap_stress_test.field_map2 +field_name: field_map2 +entity_type: node +bundle: simple_gmap_stress_test +label: map2 +description: 'A view in Quebec. Demonstrates a complex character set.' +required: true +translatable: false +default_value: + - + value: 'Place de l'Université-du-Québec, boulevard Charest Est, Québec, QC G1K' +default_value_callback: '' +settings: { } +field_type: string diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_xss.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_xss.yml new file mode 100644 index 0000000000..beb42c8da1 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.field.node.simple_gmap_stress_test.field_xss.yml @@ -0,0 +1,21 @@ +uuid: e5a33bb0-5699-46c8-bad7-196d1fc0d7ef +langcode: en +status: true +dependencies: + config: + - field.storage.node.field_xss + - node.type.simple_gmap_stress_test +id: node.simple_gmap_stress_test.field_xss +field_name: field_xss +entity_type: node +bundle: simple_gmap_stress_test +label: xss +description: 'This field demonstrates the rejection of a XSS attack.' +required: true +translatable: false +default_value: + - + value: '<script>alert("hello");</script> Empire State Building' +default_value_callback: '' +settings: { } +field_type: string diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_blank.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_blank.yml new file mode 100644 index 0000000000..8a4ea5a9a0 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_blank.yml @@ -0,0 +1,21 @@ +uuid: 7e3622d2-508a-4896-8848-2152f8db5ee5 +langcode: en +status: true +dependencies: + module: + - node +id: node.field_blank +field_name: field_blank +entity_type: node +type: string +settings: + max_length: 255 + is_ascii: false + case_sensitive: false +module: core +locked: false +cardinality: 1 +translatable: true +indexes: { } +persist_with_no_fields: false +custom_storage: false diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_map1.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_map1.yml new file mode 100644 index 0000000000..5b54d90216 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_map1.yml @@ -0,0 +1,21 @@ +uuid: ed08abe4-2bfe-4d64-89da-d8794ff1535d +langcode: en +status: true +dependencies: + module: + - node +id: node.field_map1 +field_name: field_map1 +entity_type: node +type: string +settings: + max_length: 255 + is_ascii: false + case_sensitive: false +module: core +locked: false +cardinality: 1 +translatable: true +indexes: { } +persist_with_no_fields: false +custom_storage: false diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_map2.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_map2.yml new file mode 100644 index 0000000000..498d20f7f5 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_map2.yml @@ -0,0 +1,21 @@ +uuid: 5bb62b53-fea7-4b4d-9057-67734296670b +langcode: en +status: true +dependencies: + module: + - node +id: node.field_map2 +field_name: field_map2 +entity_type: node +type: string +settings: + max_length: 255 + is_ascii: false + case_sensitive: false +module: core +locked: false +cardinality: 1 +translatable: true +indexes: { } +persist_with_no_fields: false +custom_storage: false diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_xss.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_xss.yml new file mode 100644 index 0000000000..84bce0cf89 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/field.storage.node.field_xss.yml @@ -0,0 +1,21 @@ +uuid: 581bfa0f-d8f4-413b-8cd8-a2d048a67d35 +langcode: en +status: true +dependencies: + module: + - node +id: node.field_xss +field_name: field_xss +entity_type: node +type: string +settings: + max_length: 255 + is_ascii: false + case_sensitive: false +module: core +locked: false +cardinality: 1 +translatable: true +indexes: { } +persist_with_no_fields: false +custom_storage: false diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/node.type.simple_gmap_stress_test.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/node.type.simple_gmap_stress_test.yml new file mode 100644 index 0000000000..ff2ee053c8 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/config/install/node.type.simple_gmap_stress_test.yml @@ -0,0 +1,10 @@ +uuid: 39d6d049-a8c5-4f7a-b2da-92ad2661f2ee +langcode: en +status: true +name: 'simple gmap stress test' +type: simple_gmap_stress_test +description: 'A series of field configured to utilize the simple gmap formatter. Each field test a different aspect of the formatter.' +help: '' +new_revision: true +preview_mode: 1 +display_submitted: true diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/simple_gmap_stress_test.info.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/simple_gmap_stress_test.info.yml new file mode 100644 index 0000000000..d62d5378ca --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/simple_gmap_stress_test.info.yml @@ -0,0 +1,13 @@ +name: simple_gmap_stress_test +type: module +description: 'Provides a stress_test content entity.' +package: Custom +core: 8.x +core_version_requirement: ^8 || ^9 +dependencies: + - simple_gmap + +# Information added by Drupal.org packaging script on 2020-01-20 +version: '8.x-2.0' +project: 'simple_gmap' +datestamp: 1579517590 diff --git a/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/stress_test.info.yml b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/stress_test.info.yml new file mode 100644 index 0000000000..6240b24f58 --- /dev/null +++ b/web/modules/simple_gmap/tests/module/simple_gmap_stress_test/stress_test.info.yml @@ -0,0 +1,12 @@ +name: simple_gmap_stress_test +type: module +description: 'Provides a stress_test content entity.' +package: Custom +core: 8.x +dependencies: + - simple_gmap + +# Information added by Drupal.org packaging script on 2020-01-20 +version: '8.x-2.0' +project: 'simple_gmap' +datestamp: 1579517590 diff --git a/web/modules/simple_gmap/tests/src/FunctionalJavascript/SimpleGmapTest.php b/web/modules/simple_gmap/tests/src/FunctionalJavascript/SimpleGmapTest.php new file mode 100644 index 0000000000..bc780752ec --- /dev/null +++ b/web/modules/simple_gmap/tests/src/FunctionalJavascript/SimpleGmapTest.php @@ -0,0 +1,140 @@ +<?php + +namespace Drupal\Tests\simple_gmap\FunctionalJavascript; + +use Drupal\FunctionalJavascriptTests\WebDriverTestBase; +use Drupal\node\Entity\Node; + +/** + * Creates a page to look at to test the Simple Google Maps module. + * + * Run the test, scroll to the bottom, open the last page link, and check + * what the verbose message lines say to check on that page. If you want to + * check the static maps, be sure to edit this file and put in an API key + * that is valid for static maps. + * + * @group simple_gmap + */ +class SimpleGmapTest extends WebDriverTestBase { + + /** + * {@inheritdoc} + */ + protected $defaultTheme = 'stark'; + + /** + * API key for static maps. + * + * @var string + */ + protected $apiKey = 'Static maps will not work unless you put in a key'; + + /** + * The entity object. + * + * @var Drupal\node\Entity\Node + */ + protected $node; + + /** + * Modules to enable. + * + * @var array + */ + public static $modules = [ + 'node', + // TODO can I remove menu_ui? + // (see node.type.simple_gmap_stress_test.yml) + 'menu_ui', + 'path', + 'field', + 'field_ui', + 'simple_gmap_stress_test', + 'text', + 'user', + ]; + + /** + * {@inheritdoc} + */ + protected function setUp() { + parent::setUp(); + + // Create and login as an authenticated user. + $auth_user = $this->drupalCreateUser([ + 'access content', + 'administer node display', + ]); + $this->drupalLogin($auth_user); + + // Create a stress test node with three fields where the default values + // will exercise the formatter. + $this->node = Node::create([ + 'type' => 'simple_gmap_stress_test', + 'title' => 'A three field node', + ]); + $this->node->save(); + } + + /** + * Fill out the settings form for the 'blank' field on the stress test page. + * + * The make assertions about the population of the blank settings + * summary column of the fields display table. + */ + public function testSettingsForm() { + $session = $this->getSession(); + $assert_session = $this->assertSession(); + + // To visiting the settings form we must first visitng the page + // listing all its fields. + $this->drupalGet('admin/structure/types/manage/simple_gmap_stress_test/display'); + + // Click on the row's edit button (styled with a gear icon). + $blank_row_button = $assert_session->waitForElementVisible('css', 'tr#field-blank input[alt="Edit"]'); + $this->assertNotNull($blank_row_button); + $blank_row_button->click(); + + // Wait for the settings form associated with the 'blank' field to appear + // by waiting for the update button. + $update_visible = $assert_session->waitForElementVisible('css', 'form input[value="Update"]'); + $this->assertNotNull($update_visible); + + $edit_form = $session->getPage(); + $edit_form->checkField('Include embedded dynamic map'); + $edit_form->checkField('Include embedded static map'); + + // Checking the 'static map" options causes the API key field to appear. + $visible_key = $assert_session->waitForElementVisible('css', 'label:contains("Google Maps API key")'); + $this->assertNotNull($visible_key); + + $edit_form2 = $session->getPage(); + $edit_form2->fillField('Google Maps API key', $this->apiKey); + $edit_form2->fillField('Link text', 'use_address'); + $edit_form2->fillField('Zoom level', '5'); + $edit_form2->selectFieldOption('Map type', 'Satellite'); + $edit_form2->fillField('Language', 'xyz'); + $edit_form2->checkField('Include link to map'); + $edit_form2->checkField('Include original address text'); + $edit_form2->find('css', 'input[value="Update"]')->click(); + + // As the update button completes the edit "gears" icon associated with + // the 'blank' will reappear. + $visible_gears1 = $assert_session->waitForElementVisible('css', "#field-blank input[alt=\"Edit\"]"); + $this->assertNotNull($visible_gears1); + + // Re-examine the field row containing field1. + $display_page_updated = $session->getPage(); + $field_row_updated = $display_page_updated->find('css', "#field-blank"); + + // Make assertions about the summary column. + $this->assertTrue($field_row_updated->has('css', 'div:contains("Dynamic map")')); + $this->assertTrue($field_row_updated->has('css', 'div:contains("Static map")')); + $this->assertTrue($field_row_updated->has('css', 'div:contains("Map link: use_address")')); + $this->assertTrue($field_row_updated->has('css', 'div:contains("Map Type: Satellite")')); + $this->assertTrue($field_row_updated->has('css', 'div:contains("Zoom Level: 5")')); + $this->assertTrue($field_row_updated->has('css', 'div:contains("Language: xyz")')); + $this->assertTrue($field_row_updated->has('css', 'div:contains("Original text displayed")')); + } + +} diff --git a/web/modules/simple_gmap/tests/src/Kernel/SimpleGMapFormatterTest.php b/web/modules/simple_gmap/tests/src/Kernel/SimpleGMapFormatterTest.php new file mode 100644 index 0000000000..60bad752a9 --- /dev/null +++ b/web/modules/simple_gmap/tests/src/Kernel/SimpleGMapFormatterTest.php @@ -0,0 +1,76 @@ +<?php + +namespace Drupal\Tests\simple_gmap\Kernel; + +use Drupal\KernelTests\Core\Entity\EntityKernelTestBase; + +use Drupal\node\Entity\Node; +use Drupal\Core\Render\Markup; + +/** + * Tests the text formatters functionality. + * + * @group text + */ +class SimpleGMapFormatterTest extends EntityKernelTestBase { + + /** + * Modules to enable. + * + * @var array + */ + public static $modules = ['node', 'simple_gmap', 'simple_gmap_stress_test']; + + /** + * A instance of the simple gmap stress test content type. + * + * @var \Drupal\Core\Entity\EntityInterface + */ + protected $node; + + /** + * {@inheritdoc} + */ + protected function setUp() { + parent::setUp(); + $this->installConfig('node'); + $this->installEntitySchema('node'); + $this->installConfig('simple_gmap'); + $this->installConfig('simple_gmap_stress_test'); + + // Populate the node this the default values. + $this->node = Node::create([ + 'type' => 'simple_gmap_stress_test', + 'title' => 'Stress ball', + ]); + $this->node->save(); + + } + + /** + * Inspect the formatter output. + * + * Troublesome senarious :- + * A complex character set. + * A XSS attack. + */ + public function testFormatterOutput() { + + $viewBuilder = \Drupal::entityTypeManager()->getViewBuilder('node'); + $renderer = \Drupal::service('renderer'); + + $values = [ + 'field_map2' => 'Place de l&#039;Université-du-Québec, boulevard Charest Est, Québec, QC G1K', + 'field_xss' => '<script>alert("hello");</script> Empire State Building', + ]; + + foreach ($values as $field => $raw_text) { + $view = $this->node->get($field)->view(); + $renderer->renderRoot($view[0]); + + $expected_markup = Markup::create($raw_text); + $this->assertEquals($view[0]['#children'], $expected_markup); + } + } + +} -- GitLab