Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
Zope
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
Zope
Commits
d10b435f
Commit
d10b435f
authored
May 17, 2001
by
Guido van Rossum
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update tests according to new code generation scheme.
parent
9153a4ed
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
80 additions
and
7 deletions
+80
-7
lib/python/TAL/tests/input/test16.html
lib/python/TAL/tests/input/test16.html
+2
-0
lib/python/TAL/tests/output/test16.html
lib/python/TAL/tests/output/test16.html
+1
-0
lib/python/TAL/tests/test_htmltalparser.py
lib/python/TAL/tests/test_htmltalparser.py
+77
-7
No files found.
lib/python/TAL/tests/input/test16.html
0 → 100644
View file @
d10b435f
<a
href=
"valid/link.html"
tal:attributes=
"href python:'/base/' + tag['href']"
>
blah, blah
</a>
lib/python/TAL/tests/output/test16.html
0 → 100644
View file @
d10b435f
<a
href=
"/base/valid/link.html"
>
blah, blah
</a>
lib/python/TAL/tests/test_htmltalparser.py
View file @
d10b435f
...
@@ -196,55 +196,72 @@ class TALGeneratorTestCases(TestCaseBase):
...
@@ -196,55 +196,72 @@ class TALGeneratorTestCases(TestCaseBase):
def
check_null
(
self
):
def
check_null
(
self
):
self
.
_run_check
(
""
,
[])
self
.
_run_check
(
""
,
[])
def
check_define
(
self
):
def
check_define
_1
(
self
):
self
.
_run_check
(
"<p tal:define='xyzzy string:spam'></p>"
,
[
self
.
_run_check
(
"<p tal:define='xyzzy string:spam'></p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:define'
:
'xyzzy string:spam'
}),
(
'setLocal'
,
'xyzzy'
,
'$string:spam$'
),
(
'setLocal'
,
'xyzzy'
,
'$string:spam$'
),
(
'startTag'
,
'p'
,
[(
'tal:define'
,
'xyzzy string:spam'
,
'tal'
)]),
(
'startTag'
,
'p'
,
[(
'tal:define'
,
'xyzzy string:spam'
,
'tal'
)]),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
(
'endScope'
,),
(
'endScope'
,),
])
])
def
check_define_2
(
self
):
self
.
_run_check
(
"<p tal:define='local xyzzy string:spam'></p>"
,
[
self
.
_run_check
(
"<p tal:define='local xyzzy string:spam'></p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:define'
:
'local xyzzy string:spam'
}),
(
'setLocal'
,
'xyzzy'
,
'$string:spam$'
),
(
'setLocal'
,
'xyzzy'
,
'$string:spam$'
),
(
'startTag'
,
'p'
,
(
'startTag'
,
'p'
,
[(
'tal:define'
,
'local xyzzy string:spam'
,
'tal'
)]),
[(
'tal:define'
,
'local xyzzy string:spam'
,
'tal'
)]),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
(
'endScope'
,),
(
'endScope'
,),
])
])
def
check_define_3
(
self
):
self
.
_run_check
(
"<p tal:define='global xyzzy string:spam'></p>"
,
[
self
.
_run_check
(
"<p tal:define='global xyzzy string:spam'></p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:define'
:
'global xyzzy string:spam'
}),
(
'setGlobal'
,
'xyzzy'
,
'$string:spam$'
),
(
'setGlobal'
,
'xyzzy'
,
'$string:spam$'
),
(
'startTag'
,
'p'
,
(
'startTag'
,
'p'
,
[(
'tal:define'
,
'global xyzzy string:spam'
,
'tal'
)]),
[(
'tal:define'
,
'global xyzzy string:spam'
,
'tal'
)]),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
(
'endScope'
,),
(
'endScope'
,),
])
])
def
check_define_4
(
self
):
self
.
_run_check
(
"<p tal:define='x string:spam; y x'></p>"
,
[
self
.
_run_check
(
"<p tal:define='x string:spam; y x'></p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:define'
:
'x string:spam; y x'
}),
(
'setLocal'
,
'x'
,
'$string:spam$'
),
(
'setLocal'
,
'x'
,
'$string:spam$'
),
(
'setLocal'
,
'y'
,
'$x$'
),
(
'setLocal'
,
'y'
,
'$x$'
),
(
'startTag'
,
'p'
,
[(
'tal:define'
,
'x string:spam; y x'
,
'tal'
)]),
(
'startTag'
,
'p'
,
[(
'tal:define'
,
'x string:spam; y x'
,
'tal'
)]),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
(
'endScope'
,),
(
'endScope'
,),
])
])
def
check_define_5
(
self
):
self
.
_run_check
(
"<p tal:define='x string:;;;;; y x'></p>"
,
[
self
.
_run_check
(
"<p tal:define='x string:;;;;; y x'></p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:define'
:
'x string:;;;;; y x'
}),
(
'setLocal'
,
'x'
,
'$string:;;$'
),
(
'setLocal'
,
'x'
,
'$string:;;$'
),
(
'setLocal'
,
'y'
,
'$x$'
),
(
'setLocal'
,
'y'
,
'$x$'
),
(
'startTag'
,
'p'
,
[(
'tal:define'
,
'x string:;;;;; y x'
,
'tal'
)]),
(
'startTag'
,
'p'
,
[(
'tal:define'
,
'x string:;;;;; y x'
,
'tal'
)]),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
(
'endScope'
,),
(
'endScope'
,),
])
])
def
check_define_6
(
self
):
self
.
_run_check
(
self
.
_run_check
(
"<p tal:define='x string:spam; global y x; local z y'></p>"
,
[
"<p tal:define='x string:spam; global y x; local z y'></p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:define'
:
'x string:spam; global y x; local z y'
}),
(
'setLocal'
,
'x'
,
'$string:spam$'
),
(
'setLocal'
,
'x'
,
'$string:spam$'
),
(
'setGlobal'
,
'y'
,
'$x$'
),
(
'setGlobal'
,
'y'
,
'$x$'
),
(
'setLocal'
,
'z'
,
'$y$'
),
(
'setLocal'
,
'z'
,
'$y$'
),
...
@@ -259,52 +276,81 @@ class TALGeneratorTestCases(TestCaseBase):
...
@@ -259,52 +276,81 @@ class TALGeneratorTestCases(TestCaseBase):
"<p><span tal:condition='python:1'><b>foo</b></span></p>"
,
[
"<p><span tal:condition='python:1'><b>foo</b></span></p>"
,
[
(
'rawtext'
,
'<p>'
),
(
'rawtext'
,
'<p>'
),
(
'setPosition'
,
(
1
,
3
)),
(
'setPosition'
,
(
1
,
3
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:condition'
:
'python:1'
}),
(
'condition'
,
'$python:1$'
,
(
'condition'
,
'$python:1$'
,
[(
'startTag'
,
'span'
,
[(
'tal:condition'
,
'python:1'
,
'tal'
)]),
[(
'startTag'
,
'span'
,
[(
'tal:condition'
,
'python:1'
,
'tal'
)]),
(
'rawtext'
,
'<b>foo</b></span>'
)]),
(
'rawtext'
,
'<b>foo</b></span>'
)]),
(
'endScope'
,),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
])
])
def
check_content
(
self
):
def
check_content
_1
(
self
):
self
.
_run_check
(
"<p tal:content='string:foo'>bar</p>"
,
[
self
.
_run_check
(
"<p tal:content='string:foo'>bar</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:content'
:
'string:foo'
}),
(
'startTag'
,
'p'
,
[(
'tal:content'
,
'string:foo'
,
'tal'
)]),
(
'startTag'
,
'p'
,
[(
'tal:content'
,
'string:foo'
,
'tal'
)]),
(
'insertText'
,
'$string:foo$'
,
[(
'rawtext'
,
'bar'
)]),
(
'insertText'
,
'$string:foo$'
,
[(
'rawtext'
,
'bar'
)]),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
(
'endScope'
,),
])
])
def
check_content_2
(
self
):
self
.
_run_check
(
"<p tal:content='text string:foo'>bar</p>"
,
[
self
.
_run_check
(
"<p tal:content='text string:foo'>bar</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:content'
:
'text string:foo'
}),
(
'startTag'
,
'p'
,
[(
'tal:content'
,
'text string:foo'
,
'tal'
)]),
(
'startTag'
,
'p'
,
[(
'tal:content'
,
'text string:foo'
,
'tal'
)]),
(
'insertText'
,
'$string:foo$'
,
[(
'rawtext'
,
'bar'
)]),
(
'insertText'
,
'$string:foo$'
,
[(
'rawtext'
,
'bar'
)]),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
(
'endScope'
,),
])
])
def
check_content_3
(
self
):
self
.
_run_check
(
"<p tal:content='structure string:<br>'>bar</p>"
,
[
self
.
_run_check
(
"<p tal:content='structure string:<br>'>bar</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:content'
:
'structure string:<br>'
}),
(
'startTag'
,
'p'
,
(
'startTag'
,
'p'
,
[(
'tal:content'
,
'structure string:<br>'
,
'tal'
)]),
[(
'tal:content'
,
'structure string:<br>'
,
'tal'
)]),
(
'insertStructure'
,
'$string:<br>$'
,
{},
[(
'rawtext'
,
'bar'
)]),
(
'insertStructure'
,
'$string:<br>$'
,
{},
[(
'rawtext'
,
'bar'
)]),
(
'rawtext'
,
'</p>'
),
(
'rawtext'
,
'</p>'
),
(
'endScope'
,),
])
])
def
check_replace
(
self
):
def
check_replace
_1
(
self
):
self
.
_run_check
(
"<p tal:replace='string:foo'>bar</p>"
,
[
self
.
_run_check
(
"<p tal:replace='string:foo'>bar</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:replace'
:
'string:foo'
}),
(
'insertText'
,
'$string:foo$'
,
(
'insertText'
,
'$string:foo$'
,
[(
'startTag'
,
'p'
,
[(
'tal:replace'
,
'string:foo'
,
'tal'
)]),
[(
'startTag'
,
'p'
,
[(
'tal:replace'
,
'string:foo'
,
'tal'
)]),
(
'rawtext'
,
'bar</p>'
)]),
(
'rawtext'
,
'bar</p>'
)]),
(
'endScope'
,),
])
])
def
check_replace_2
(
self
):
self
.
_run_check
(
"<p tal:replace='text string:foo'>bar</p>"
,
[
self
.
_run_check
(
"<p tal:replace='text string:foo'>bar</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:replace'
:
'text string:foo'
}),
(
'insertText'
,
'$string:foo$'
,
(
'insertText'
,
'$string:foo$'
,
[(
'startTag'
,
'p'
,
[(
'tal:replace'
,
'text string:foo'
,
'tal'
)]),
[(
'startTag'
,
'p'
,
[(
'tal:replace'
,
'text string:foo'
,
'tal'
)]),
(
'rawtext'
,
'bar</p>'
)]),
(
'rawtext'
,
'bar</p>'
)]),
(
'endScope'
,),
])
])
def
check_replace_3
(
self
):
self
.
_run_check
(
"<p tal:replace='structure string:<br>'>bar</p>"
,
[
self
.
_run_check
(
"<p tal:replace='structure string:<br>'>bar</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:replace'
:
'structure string:<br>'
}),
(
'insertStructure'
,
'$string:<br>$'
,
{},
(
'insertStructure'
,
'$string:<br>$'
,
{},
[(
'startTag'
,
'p'
,
[(
'startTag'
,
'p'
,
[(
'tal:replace'
,
'structure string:<br>'
,
'tal'
)]),
[(
'tal:replace'
,
'structure string:<br>'
,
'tal'
)]),
(
'rawtext'
,
'bar</p>'
)]),
(
'rawtext'
,
'bar</p>'
)]),
(
'endScope'
,),
])
])
def
check_repeat
(
self
):
def
check_repeat
(
self
):
...
@@ -312,21 +358,29 @@ class TALGeneratorTestCases(TestCaseBase):
...
@@ -312,21 +358,29 @@ class TALGeneratorTestCases(TestCaseBase):
"<span tal:replace='x'>dummy</span></p>"
,
[
"<span tal:replace='x'>dummy</span></p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:repeat'
:
'x python:(1,2,3)'
}),
(
'loop'
,
'x'
,
'$python:(1,2,3)$'
,
(
'loop'
,
'x'
,
'$python:(1,2,3)$'
,
[(
'startTag'
,
'p'
,
[(
'tal:repeat'
,
'x python:(1,2,3)'
,
'tal'
)]),
[(
'startTag'
,
'p'
,
[(
'tal:repeat'
,
'x python:(1,2,3)'
,
'tal'
)]),
(
'setPosition'
,
(
1
,
33
)),
(
'setPosition'
,
(
1
,
33
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:replace'
:
'x'
}),
(
'insertText'
,
'$x$'
,
(
'insertText'
,
'$x$'
,
[(
'startTag'
,
'span'
,
[(
'tal:replace'
,
'x'
,
'tal'
)]),
[(
'startTag'
,
'span'
,
[(
'tal:replace'
,
'x'
,
'tal'
)]),
(
'rawtext'
,
'dummy</span>'
)]),
(
'rawtext'
,
'dummy</span>'
)]),
(
'endScope'
,),
(
'rawtext'
,
'</p>'
)]),
(
'rawtext'
,
'</p>'
)]),
(
'endScope'
,),
(
'endScope'
,),
])
])
def
check_attributes
(
self
):
def
check_attributes
_1
(
self
):
self
.
_run_check
(
"<a href='foo' name='bar' tal:attributes="
self
.
_run_check
(
"<a href='foo' name='bar' tal:attributes="
"'href string:http://www.zope.org; x string:y'>"
"'href string:http://www.zope.org; x string:y'>"
"link</a>"
,
[
"link</a>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:attributes'
:
'href string:http://www.zope.org; x string:y'
,
'name'
:
'bar'
,
'href'
:
'foo'
}),
(
'startTag'
,
'a'
,
(
'startTag'
,
'a'
,
[(
'href'
,
'foo'
,
'replace'
,
'$string:http://www.zope.org$'
),
[(
'href'
,
'foo'
,
'replace'
,
'$string:http://www.zope.org$'
),
(
'name'
,
'bar'
),
(
'name'
,
'bar'
),
...
@@ -334,22 +388,33 @@ class TALGeneratorTestCases(TestCaseBase):
...
@@ -334,22 +388,33 @@ class TALGeneratorTestCases(TestCaseBase):
'href string:http://www.zope.org; x string:y'
,
'tal'
),
'href string:http://www.zope.org; x string:y'
,
'tal'
),
(
'x'
,
None
,
'insert'
,
'$string:y$'
)]),
(
'x'
,
None
,
'insert'
,
'$string:y$'
)]),
(
'rawtext'
,
'link</a>'
),
(
'rawtext'
,
'link</a>'
),
(
'endScope'
,),
])
])
def
check_attributes_2
(
self
):
self
.
_run_check
(
"<p tal:replace='structure string:<img>' "
self
.
_run_check
(
"<p tal:replace='structure string:<img>' "
"tal:attributes='src string:foo.png'>duh</p>"
,
[
"tal:attributes='src string:foo.png'>duh</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:attributes'
:
'src string:foo.png'
,
'tal:replace'
:
'structure string:<img>'
}),
(
'insertStructure'
,
'$string:<img>$'
,
(
'insertStructure'
,
'$string:<img>$'
,
{
'src'
:
'$string:foo.png$'
},
{
'src'
:
'$string:foo.png$'
},
[(
'startTag'
,
'p'
,
[(
'startTag'
,
'p'
,
[(
'tal:replace'
,
'structure string:<img>'
,
'tal'
),
[(
'tal:replace'
,
'structure string:<img>'
,
'tal'
),
(
'tal:attributes'
,
'src string:foo.png'
,
'tal'
)]),
(
'tal:attributes'
,
'src string:foo.png'
,
'tal'
)]),
(
'rawtext'
,
'duh</p>'
)]),
(
'rawtext'
,
'duh</p>'
)]),
(
'endScope'
,),
])
])
def
check_on_error
(
self
):
def
check_on_error
_1
(
self
):
self
.
_run_check
(
"<p tal:on-error='string:error' "
self
.
_run_check
(
"<p tal:on-error='string:error' "
"tal:content='notHere'>okay</p>"
,
[
"tal:content='notHere'>okay</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:content'
:
'notHere'
,
'tal:on-error'
:
'string:error'
}),
(
'onError'
,
(
'onError'
,
[(
'startTag'
,
'p'
,
[(
'startTag'
,
'p'
,
[(
'tal:on-error'
,
'string:error'
,
'tal'
),
[(
'tal:on-error'
,
'string:error'
,
'tal'
),
...
@@ -361,10 +426,16 @@ class TALGeneratorTestCases(TestCaseBase):
...
@@ -361,10 +426,16 @@ class TALGeneratorTestCases(TestCaseBase):
(
'tal:content'
,
'notHere'
,
'tal'
)]),
(
'tal:content'
,
'notHere'
,
'tal'
)]),
(
'insertText'
,
'$string:error$'
,
[]),
(
'insertText'
,
'$string:error$'
,
[]),
(
'rawtext'
,
'</p>'
)]),
(
'rawtext'
,
'</p>'
)]),
(
'endScope'
,),
])
])
def
check_on_error_2
(
self
):
self
.
_run_check
(
"<p tal:on-error='string:error' "
self
.
_run_check
(
"<p tal:on-error='string:error' "
"tal:replace='notHere'>okay</p>"
,
[
"tal:replace='notHere'>okay</p>"
,
[
(
'setPosition'
,
(
1
,
0
)),
(
'setPosition'
,
(
1
,
0
)),
(
'beginScope'
,),
(
'tagDict'
,
{
'tal:replace'
:
'notHere'
,
'tal:on-error'
:
'string:error'
}),
(
'onError'
,
(
'onError'
,
[(
'insertText'
,
'$notHere$'
,
[(
'insertText'
,
'$notHere$'
,
[(
'startTag'
,
'p'
,
[(
'startTag'
,
'p'
,
...
@@ -376,6 +447,7 @@ class TALGeneratorTestCases(TestCaseBase):
...
@@ -376,6 +447,7 @@ class TALGeneratorTestCases(TestCaseBase):
(
'tal:replace'
,
'notHere'
,
'tal'
)]),
(
'tal:replace'
,
'notHere'
,
'tal'
)]),
(
'insertText'
,
'$string:error$'
,
[]),
(
'insertText'
,
'$string:error$'
,
[]),
(
'rawtext'
,
'</p>'
)]),
(
'rawtext'
,
'</p>'
)]),
(
'endScope'
,),
])
])
def
check_dup_attr
(
self
):
def
check_dup_attr
(
self
):
...
@@ -393,8 +465,6 @@ class TALGeneratorTestCases(TestCaseBase):
...
@@ -393,8 +465,6 @@ class TALGeneratorTestCases(TestCaseBase):
def
check_metal_errors
(
self
):
def
check_metal_errors
(
self
):
exc
=
METALError
exc
=
METALError
self
.
_should_error
(
2
*
"<p metal:define-macro='x'>xxx</p>"
,
exc
)
self
.
_should_error
(
2
*
"<p metal:define-macro='x'>xxx</p>"
,
exc
)
## self._should_error("<html metal:define-macro='x'>" +
## 2*"<p metal:define-slot='y' />" + "</html>")
self
.
_should_error
(
"<html metal:use-macro='x'>"
+
self
.
_should_error
(
"<html metal:use-macro='x'>"
+
2
*
"<p metal:fill-slot='y' />"
+
"</html>"
,
exc
)
2
*
"<p metal:fill-slot='y' />"
+
"</html>"
,
exc
)
self
.
_should_error
(
"<p metal:foobar='x' />"
,
exc
)
self
.
_should_error
(
"<p metal:foobar='x' />"
,
exc
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment