File: test_xmlnode.py

package info (click to toggle)
python-flickrapi 2.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 468 kB
  • sloc: python: 2,145; makefile: 147; sh: 10
file content (118 lines) | stat: -rw-r--r-- 4,738 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# -*- encoding: utf-8 -*-

'''Unittest for the flickrapi.tokencache module'''

import unittest
import sys

# Make sure the flickrapi module from the source distribution is used
sys.path.insert(0, '..')

from flickrapi.xmlnode import XMLNode

# This XML is used in the tests
xml = '''<?xml version="1.0" encoding="utf-8"?>
<rsp stat="ok">
  <photo id="2141453991">
    <owner nsid="73509078@N00" username="Sybren Stüvel" location="The Netherlands"/>
    <title>threesixtyfive | day 115</title>
    <description>An eye for an eye?</description>
    <visibility ispublic="1" isfriend="0" isfamily="0"/>
    <dates posted="1198790234" taken="2007-12-26 13:41:48" takengranularity="0" lastupdate="1198838228"/>
    <editability cancomment="0" canaddmeta="0"/>
    <usage candownload="1" canblog="0" canprint="0"/>
    <comments>3</comments>
    <notes/>
    <tags>
      <tag id="6764206-2141453991-24181" author="73509078@N00" raw="365" machine_tag="0">365</tag>
      <tag id="6764206-2141453991-1977798" author="73509078@N00" raw="365days" machine_tag="0">365days</tag>
      <tag id="6764206-2141453991-7424031" author="73509078@N00" raw="threesixtyfive" machine_tag="0">threesixtyfive</tag>
      <tag id="6764206-2141453991-731" author="73509078@N00" raw="me" machine_tag="0">me</tag>
      <tag id="6764206-2141453991-411" author="73509078@N00" raw="selfportrait" machine_tag="0">selfportrait</tag>
      <tag id="6764206-2141453991-1200512" author="73509078@N00" raw="Sybren" machine_tag="0">sybren</tag>
      <tag id="6764206-2141453991-11836799" author="73509078@N00" raw="lens:type=17-55mm F/2.8 IS USM" machine_tag="1">lens:type=1755mmf28isusm</tag>
      <tag id="6764206-2141453991-60951" author="73509078@N00" raw="merge" machine_tag="0">merge</tag>
      <tag id="6764206-2141453991-8124" author="73509078@N00" raw="twin" machine_tag="0">twin</tag>
      <tag id="6764206-2141453991-1031" author="73509078@N00" raw="tongue" machine_tag="0">tongue</tag>
      <tag id="6764206-2141453991-935" author="73509078@N00" raw="Amsterdam" machine_tag="0">amsterdam</tag>
      <tag id="6764206-2141453991-7931" author="73509078@N00" raw="gimp" machine_tag="0">gimp</tag>
      <tag id="6764206-2141453991-39180" author="73509078@N00" raw="the gimp" machine_tag="0">thegimp</tag>
    </tags>
    <urls>
      <url type="photopage">
          http://www.flickr.com/photos/sybrenstuvel/2141453991/
      </url>
    </urls>
  </photo>
</rsp>
'''

group_info_xml = '''<?xml version="1.0" encoding="utf-8"?>
<rsp stat="ok">
  <group id="51035612836@N01" iconserver="1" iconfarm="1" lang="en-us" ispoolmoderated="1">
    <name>Flickr
API</name>
    <description>A Flickr group for Flickr API projects.

Driving awareness of the Flickr API, projects that use it and
those incredible ideas that programmatically exposed systems produce.
Think Google API + Amazon API + Flickr API with a bit of GMail thrown
in.

The developers of Flickr rightly pointed out they want to
keep technical discussions directly related to the API on the mailing
list.</description>
    <members>5180</members>
    <privacy>3</privacy>
    <throttle count="3" mode="day"/>
  </group>
</rsp>
'''


class TestXMLNode(unittest.TestCase):

    def setUp(self):
        self.doc = XMLNode.parse(xml, True)

    def testXmlStorage(self):
        '''Tests that the XML stored in the parsed document
        is equal to the XML fed to it.
        '''

        self.assertEqual(self.doc.xml, xml)

    def testParsing(self):
        '''Tests that parsing of XML works as expected.'''

        self.assertEqual(self.doc.photo[0]['id'], '2141453991')
        self.assertEqual(self.doc.photo[0].comments[0].text, '3')
        self.assertEqual(self.doc.photo[0].comments[0].name, u'comments')
        self.assertEqual(self.doc.photo[0].owner[0]['username'], u"Sybren Stüvel")

    def testGroupInfoXml(self):
        '''This XML exposed a bug in 1.0, should parse okay now.'''

        XMLNode.parse(group_info_xml)

    def testMoreParsing(self):
        '''Tests parsing of XML.

        This used to be a doctest, but it was very hard to make it compatible
        with both Python 2 and 3.
        '''

        xml_str = '''<xml foo="32">
            <taggy bar="10">Name0</taggy>
            <taggy bar="11" baz="12">Name1</taggy>
            </xml>'''

        f = XMLNode.parse(xml_str)
        self.assertEqual(f.name, 'xml')
        self.assertEqual(f['foo'], '32')
        self.assertEqual(f.taggy[0].name, 'taggy')
        self.assertEqual(f.taggy[0]["bar"], '10')
        self.assertEqual(f.taggy[0].text, 'Name0')
        self.assertEqual(f.taggy[1].name, 'taggy')
        self.assertEqual(f.taggy[1]["bar"], '11')
        self.assertEqual(f.taggy[1]["baz"], '12')