A Python parser for MediaWiki wikicode https://mwparserfromhell.readthedocs.io/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

98 lines
3.6 KiB

  1. #
  2. # Copyright (C) 2012-2016 Ben Kurtovic <ben.kurtovic@gmail.com>
  3. #
  4. # Permission is hereby granted, free of charge, to any person obtaining a copy
  5. # of this software and associated documentation files (the "Software"), to deal
  6. # in the Software without restriction, including without limitation the rights
  7. # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. # copies of the Software, and to permit persons to whom the Software is
  9. # furnished to do so, subject to the following conditions:
  10. #
  11. # The above copyright notice and this permission notice shall be included in
  12. # all copies or substantial portions of the Software.
  13. #
  14. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  20. # SOFTWARE.
  21. import pytest
  22. from mwparserfromhell.parser import tokens
  23. class TestTokens:
  24. """Test cases for the Token class and its subclasses."""
  25. @pytest.mark.parametrize("name", tokens.__all__)
  26. def test_issubclass(self, name):
  27. """check that all classes within the tokens module are really Tokens"""
  28. klass = getattr(tokens, name)
  29. assert issubclass(klass, tokens.Token) is True
  30. assert isinstance(klass(), klass)
  31. assert isinstance(klass(), tokens.Token)
  32. def test_attributes(self):
  33. """check that Token attributes can be managed properly"""
  34. token1 = tokens.Token()
  35. token2 = tokens.Token(foo="bar", baz=123)
  36. assert "bar" == token2.foo
  37. assert 123 == token2.baz
  38. assert token1.foo is None
  39. assert token2.bar is None
  40. token1.spam = "eggs"
  41. token2.foo = "ham"
  42. del token2.baz
  43. assert "eggs" == token1.spam
  44. assert "ham" == token2.foo
  45. assert token2.baz is None
  46. with pytest.raises(KeyError):
  47. token2.__delattr__("baz")
  48. def test_repr(self):
  49. """check that repr() on a Token works as expected"""
  50. token1 = tokens.Token()
  51. token2 = tokens.Token(foo="bar", baz=123)
  52. token3 = tokens.Text(text="earwig" * 100)
  53. hundredchars = ("earwig" * 100)[:97] + "..."
  54. assert "Token()" == repr(token1)
  55. token2repr1 = "Token(foo='bar', baz=123)"
  56. token2repr2 = "Token(baz=123, foo='bar')"
  57. token3repr = "Text(text='" + hundredchars + "')"
  58. token2repr = repr(token2)
  59. assert token2repr == token2repr1 or token2repr == token2repr2
  60. assert token3repr == repr(token3)
  61. def test_equality(self):
  62. """check that equivalent tokens are considered equal"""
  63. token1 = tokens.Token()
  64. token2 = tokens.Token()
  65. token3 = tokens.Token(foo="bar", baz=123)
  66. token4 = tokens.Text(text="asdf")
  67. token5 = tokens.Text(text="asdf")
  68. token6 = tokens.TemplateOpen(text="asdf")
  69. assert token1 == token2
  70. assert token2 == token1
  71. assert token4 == token5
  72. assert token5 == token4
  73. assert token1 != token3
  74. assert token2 != token3
  75. assert token4 != token6
  76. assert token5 != token6
  77. @pytest.mark.parametrize("token", [
  78. tokens.Token(),
  79. tokens.Token(foo="bar", baz=123),
  80. tokens.Text(text="earwig")
  81. ])
  82. def test_repr_equality(self, token):
  83. """check that eval(repr(token)) == token"""
  84. assert token == eval(repr(token), vars(tokens))