multiple-tests.js 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. module('Selection containers - Multiple');
  2. var MultipleSelection = require('select2/selection/multiple');
  3. var $ = require('jquery');
  4. var Options = require('select2/options');
  5. var Utils = require('select2/utils');
  6. var options = new Options({});
  7. test('display uses templateSelection', function (assert) {
  8. var called = false;
  9. var templateOptions = new Options({
  10. templateSelection: function (data) {
  11. called = true;
  12. return data.text;
  13. }
  14. });
  15. var selection = new MultipleSelection(
  16. $('#qunit-fixture .multiple'),
  17. templateOptions
  18. );
  19. var out = selection.display({
  20. text: 'test'
  21. });
  22. assert.ok(called);
  23. assert.equal(out, 'test');
  24. });
  25. test('templateSelection can addClass', function (assert) {
  26. var called = false, found = false;
  27. var templateOptions = new Options({
  28. templateSelection: function (data, container) {
  29. called = true;
  30. container.addClass('testclass');
  31. return data.text;
  32. }
  33. });
  34. var selection = new MultipleSelection(
  35. $('#qunit-fixture .multiple'),
  36. templateOptions
  37. );
  38. var $container = selection.selectionContainer();
  39. var out = selection.display({
  40. text: 'test'
  41. }, $container);
  42. for (var i = 0; i < $container[0].classList.length; i += 1) {
  43. if ($container[0].classList[i] === 'testclass') {
  44. found = true;
  45. }
  46. }
  47. assert.ok(called);
  48. assert.equal(out, 'test');
  49. assert.ok(called);
  50. });
  51. test('empty update clears the selection', function (assert) {
  52. var selection = new MultipleSelection(
  53. $('#qunit-fixture .multiple'),
  54. options
  55. );
  56. var $selection = selection.render();
  57. var $rendered = $selection.find('.select2-selection__rendered');
  58. $rendered.text('testing');
  59. selection.update([]);
  60. assert.equal($rendered.text(), '');
  61. });
  62. test('escapeMarkup is being used', function (assert) {
  63. var selection = new MultipleSelection(
  64. $('#qunit-fixture .multiple'),
  65. options
  66. );
  67. var $selection = selection.render();
  68. var $rendered = $selection.find('.select2-selection__rendered');
  69. var unescapedText = '<script>bad("stuff");</script>';
  70. selection.update([{
  71. text: unescapedText
  72. }]);
  73. assert.equal(
  74. $rendered.text().substr(1),
  75. unescapedText,
  76. 'The text should be escaped by default to prevent injection'
  77. );
  78. });