[tracker/miner-web-review: 29/74] libtracker-data: New functional test cases added
- From: Adrien Bustany <abustany src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/miner-web-review: 29/74] libtracker-data: New functional test cases added
- Date: Mon, 1 Mar 2010 15:34:39 +0000 (UTC)
commit ab913130d7f4474dc1210f543420050546bdae15
Author: Amit Jain <ext-amit 1 jain nokia com>
Date: Thu Feb 25 11:00:15 2010 +0100
libtracker-data: New functional test cases added
New test cases for SPARQL UPDATE queries for insertion and deletion
operations. New test cases for dates storage verification as per
sprint task MCoFr-406.
tests/functional-tests/01-insertion.py | 747 ++++++++++++++++++++++++++++++--
1 files changed, 704 insertions(+), 43 deletions(-)
---
diff --git a/tests/functional-tests/01-insertion.py b/tests/functional-tests/01-insertion.py
index 4b1f9e8..3ed45a2 100755
--- a/tests/functional-tests/01-insertion.py
+++ b/tests/functional-tests/01-insertion.py
@@ -16,55 +16,716 @@
# License along with this library; if not, write to the
# Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
# Boston, MA 02110-1301, USA.
-#
-import dbus
+import sys,os,dbus
import unittest
+import time
import random
TRACKER = 'org.freedesktop.Tracker1'
TRACKER_OBJ = '/org/freedesktop/Tracker1/Resources'
RESOURCES_IFACE = "org.freedesktop.Tracker1.Resources"
-class TestInsertion (unittest.TestCase):
-
- def setUp (self):
- bus = dbus.SessionBus ()
- tracker = bus.get_object (TRACKER, TRACKER_OBJ)
- self.resources = dbus.Interface (tracker,
- dbus_interface=RESOURCES_IFACE);
-
- def test_simple_insertion (self):
- """
- 1. Insert a InformationElement with title.
- 2. TEST: Query the title of that information element
- 3. Remove the InformationElement to keep everything as it was before
- """
-
- uri = "tracker://test_insertion_1/" + str(random.randint (0, 100))
-
- insert = """
- INSERT { <%s> a nie:InformationElement;
- nie:title \"test_insertion_1\". }
- """ % (uri)
- self.resources.SparqlUpdate (insert)
-
- query = """
- SELECT ?t WHERE {
- <%s> a nie:InformationElement ;
- nie:title ?t .
- }
- """ % (uri)
- results = self.resources.SparqlQuery (query)
-
- self.assertEquals (str(results[0][0]), "test_insertion_1")
-
- delete = """
- DELETE { <%s> a nie:InformationElement. }
- """ % (uri)
- self.resources.SparqlUpdate (delete)
-
-
-if __name__ == '__main__':
- unittest.main()
+
+class TestUpdate (unittest.TestCase):
+
+ def setUp(self):
+ bus = dbus.SessionBus()
+ tracker = bus.get_object(TRACKER, TRACKER_OBJ)
+ self.resources = dbus.Interface (tracker,
+ dbus_interface=RESOURCES_IFACE)
+
+
+ def sparql_update(self,query):
+ return self.resources.SparqlUpdate(query)
+
+ def query(self,query):
+ return self.resources.SparqlQuery(query)
+
+
+""" Insertion test cases """
+class s_insert(TestUpdate):
+
+
+ def test_insert_01(self):
+
+ """
+ 1. Insert a InformationElement with title.
+ 2. TEST: Query the title of that information element
+ 3. Remove the InformationElement to keep everything as it was before
+ """
+
+ uri = "tracker://test_insert_01/" + str(random.randint (0, 100))
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:title \"test_insert_01\". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+ query = """
+ SELECT ?t WHERE {
+ <%s> a nie:InformationElement ;
+ nie:title ?t .
+ }
+ """ % (uri)
+ results = self.query (query)
+
+ self.assertEquals (str(results[0][0]), "test_insert_01")
+
+ """ delete the inserted item """
+ delete = """
+ DELETE { <%s> a nie:InformationElement. }
+ """ % (uri)
+ self.sparql_update (delete)
+
+
+ def test_insert_02(self):
+ ''' SparqlUpdate: Insert triples and check using SparqlQuery'''
+
+ self.sparql_update('INSERT {<urn:uuid:7646007> a nco:Contact; \
+ nco:fullname "Artist_1_update". \
+ <file:///media/PIKKUTIKKU/5000_songs_with_metadata_and_album_arts/Artist_1/1_Album/10_song3.mp3> a nmm:MusicPiece,nfo:FileDataObject,nmm:MusicAlbum;\
+ nfo:fileName "10_song.mp3"; \
+ nfo:fileLastModified "2008-10-23T13:47:02" ; \
+ nfo:fileCreated "2008-12-16T12:41:20"; \
+ nfo:fileSize 17630; \
+ nmm:length 219252; \
+ nmm:albumTitle "anything".}')
+
+ self.verify_test_insert_02()
+
+
+ def verify_test_insert_02(self):
+
+ result = self.query('SELECT ?artist ?date WHERE{ \
+ ?contact nco:fullname ?artist . \
+ ?time nfo:fileCreated ?date . \
+ FILTER (?artist = "Artist_1_update") \
+ }')
+ print result
+
+ for i in range(len(result)):
+ if result[i][0] == 'Artist_1_update':
+ if result[i][1] == 'anything' and result[i][2] == '219252':
+ self.assert_(True,'Pass')
+ return
+ else:
+ if i < range(len(result) - 1):
+ continue
+ else:
+ self.fail('Fail %s' %result)
+
+
+ def test_insert_03(self):
+ ''' SparqlUpdate: Insert triples and check using SparqlQuery'''
+
+ self.sparql_update('INSERT {<urn:uuid:7646004> a nco:Contact; \
+ nco:fullname "Artist_4_update". \
+ <file:///media/PIKKUTIKKU/5000_songs_with_metadata_and_album_arts/Artist_4/4_Album/4_song_1.mp3> a nmm:MusicPiece,nfo:FileDataObject;\
+ nfo:fileName "4_song_1.mp3"; \
+ nfo:fileCreated "2008-12-16T12:41:20"; \
+ nfo:fileLastModified "2008-12-23T13:47:02" ; \
+ nfo:fileSize 17630; \
+ nmm:musicAlbum "4_Album_update"; \
+ nmm:trackNumber "11"; \
+ nmm:length 219252; \
+ nmm:performer <urn:uuid:7646004>.}')
+
+ self.verify_test_insert_03()
+
+
+ def verify_test_insert_03(self):
+
+ result = self.query('SELECT ?artist ?album ?len ?trkNo ?fname ?fSz WHERE{ \
+ ?contact nco:fullname ?artist . \
+ ?song nmm:musicAlbum ?album ; \
+ nmm:length ?len ;\
+ nmm:trackNumber ?trkNo.\
+ ?songfile nfo:fileName ?fname ;\
+ nfo:fileSize ?fSz .\
+ FILTER (?fname = "4_song_1.mp3") \
+ }')
+ print len(result)
+
+ for i in range(len(result)):
+ if result[i][0] == 'Artist_4_update':
+ if result[i][1] == '4_Album_update' and result[i][2] == '219252' and result[i][3] == '11' and result[i][4] == '4_song_1.mp3' and result[i][5] == '17630':
+ self.assert_(True,'Pass')
+ return
+ else:
+ if i < range(len(result) - 1):
+ continue
+ else:
+ self.fail('Fail %s' %result)
+
+ def test_insert_04(self):
+ """Insert, delete same single valued properties multiple times."""
+
+ """ Delete single valued properties of music file."""
+ self.sparql_update('DELETE { <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> nie:usageCounter ?v } WHERE { \
+ <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> nie:usageCounter ?v . }')
+ self.sparql_update('DELETE { <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> nie:contentAccessed ?v } WHERE { \
+ <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> nie:contentAccessed ?v . }')
+
+
+ """ Insert the same single valued properties of music file."""
+ self.sparql_update('INSERT { \
+ <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> a nmm:MusicPiece,nfo:FileDataObject;\
+ nie:usageCounter "1"; \
+ nie:contentAccessed "2000-01-01T00:40:47Z" . }')
+
+ """ Delete again the single valued properties of music file."""
+ self.sparql_update('DELETE { <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> nie:usageCounter ?v } WHERE { \
+ <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> nie:usageCounter ?v . }')
+ self.sparql_update('DELETE { <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> nie:contentAccessed ?v } WHERE { \
+ <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> nie:contentAccessed ?v . }')
+
+
+ """ Insert the same single valued properties of music file with different values."""
+ self.sparql_update('INSERT { \
+ <file:///media/PIKKUTIKKU/album_4/4_song4.mp3> a nmm:MusicPiece,nfo:FileDataObject;\
+ nie:usageCounter "2"; \
+ nie:contentAccessed "2000-01-01T00:40:48Z" . }')
+
+ """ Query for the property values and verify whether the last change is applied."""
+ result = self.query('SELECT ?song ?time WHERE{ \
+ ?song nie:usageCounter "2"; \
+ nie:contentAccessed ?time . \
+ }')
+ print len(result)
+
+ for i in range(len(result)):
+ if result[i][0] == 'file:///media/PIKKUTIKKU/album_4/4_song4.mp3':
+ if result[i][1] == '2000-01-01T00:40:48Z':
+ self.assert_(True,'Pass')
+ else:
+ self.fail('Fail %s' %result)
+
+
+ """Date-Time storage testing """
+
+ def test_insert_date_01(self):
+
+ """
+ 1. Insert a InformationElement with date having local timezone info.
+ 2. TEST: Query and verify the various componentes of date
+ """
+
+ uri = "tracker:test_date_01"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "2004-05-06T13:14:15+0400". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+ print result
+
+ for i in range(len(result)):
+ if result[i][0] == 'tracker:test_date_01':
+ if result[i][1] == '2004' and result[i][2] == '05' and result[i][3] == '06' and result[i][4] == '13' and result[i][5] == '14' and result[i][6] == '15' and result[i][7] == '14400' :
+ self.assert_(True,'Pass')
+ else:
+ self.fail('Fail %s' %result)
+
+ def test_insert_date_02(self):
+
+ """
+ 1. Insert a InformationElement with invalid year in date.
+ 2. TEST: Query and verify the various componentes of date
+ """
+
+ uri = "tracker:test_date_02"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "204-05-06T13:14:15+0400". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+ print result
+
+ for i in range(len(result)):
+ if result[i][0] == 'tracker:test_date_02':
+ if result[i][1] != '204':
+ self.assert_(True,'Pass')
+ else:
+ self.fail('Fail %s' %result)
+
+
+ def test_insert_date_03(self):
+
+ """
+ 1. Insert a InformationElement with date ending with "Z" in TZD.
+ 2. TEST: Query and verify the various componentes of date
+ """
+
+ uri = "tracker:test_date_03"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "2004-05-06T13:14:15Z". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+ print result
+
+ for i in range(len(result)):
+ if result[i][0] == 'tracker:test_date_03':
+ if result[i][1] == '2004' and result[i][2] == '05' and result[i][3] == '06' and result[i][4] == '13' and result[i][5] == '14' and result[i][6] == '15' and result[i][7] == '0' :
+ self.assert_(True,'Pass')
+ else:
+ self.fail('Fail %s' %result)
+
+
+ def test_insert_date_04(self):
+
+ """
+ 1. Insert a InformationElement with date without TZD.
+ 2. TEST: Query and verify the various componentes of date
+ """
+
+ uri = "tracker:test_date_04"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "2004-05-06T13:14:15". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+ print result
+
+ for i in range(len(result)):
+ if result[i][0] == 'tracker:test_date_04':
+ if result[i][1] == '2004' and result[i][2] == '05' and result[i][3] == '06' and result[i][4] == '13' and result[i][5] == '14' and result[i][6] == '15' and result[i][7] == '0' :
+ self.assert_(True,'Pass')
+ else:
+ self.fail('Fail %s' %result)
+
+
+ def test_insert_date_05(self):
+
+ """
+ 1. Insert a InformationElement with date without time.
+ 2. TEST: Query and verify the various componentes of date
+ """
+
+ uri = "tracker:test_date_05"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "2004-05-06". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+ print result
+
+ for i in range(len(result)):
+ if result[i][1] == '2004' and result[i][2] == '05' and result[i][3] == '06':
+ self.assert_(True,'Pass')
+ else:
+ print result[i]
+ self.fail('Fail %s' %result)
+
+
+ def test_insert_date_06(self):
+
+ """
+ 1. Insert a InformationElement with date without time but only the "T" separator.
+ """
+
+ uri = "tracker:test_date_06"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "2004-05-06T". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+ print result
+
+ for i in range(len(result)):
+ if result[i][0] == 'tracker:test_date_06':
+ if result[i][1] == '2004' and result[i][2] == '05' and result[i][3] == '06' :
+ self.assert_(True,'Pass')
+ else:
+ print result[i]
+ self.fail('Fail %s' %result)
+
+ def test_insert_date_07(self):
+
+ """
+ 1. Insert a InformationElement with date having local timezone info
+ with some minutes in it.
+ 2. TEST: Query and verify the various componentes of date
+ """
+
+ uri = "tracker:test_date_07"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "2004-05-06T13:14:15+0230". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+
+ for i in range(len(result)):
+ if result[i][0] == 'tracker:test_date_07':
+ if result[i][1] == '2004' and result[i][2] == '05' and result[i][3] == '06' and result[i][4] == '13' and result[i][5] == '14' and result[i][6] == '15' and result[i][7] == '9000':
+ self.assert_(True,'Pass')
+ else:
+ print result[i]
+ self.fail('Fail %s' %result)
+
+ def test_insert_date_08(self):
+
+ """
+ 1. Insert a InformationElement with date having
+ local timezone info in negative.
+ 2. TEST: Query and verify the various componentes of date
+ """
+
+ uri = "tracker:test_date_08"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "2004-05-06T13:14:15-0230". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+
+ for i in range(len(result)):
+ if result[i][0] == 'tracker:test_date_08':
+ if result[i][1] == '2004' and result[i][2] == '05' and result[i][3] == '06' and result[i][4] == '13' and result[i][5] == '14' and result[i][6] == '15' and result[i][7] == '-9000':
+ self.assert_(True,'Pass')
+ else:
+ print result[i]
+ self.fail('Fail %s' %result)
+
+ def test_insert_date_09(self):
+
+ """
+ 1. Insert a InformationElement with date having some letters instead of numbers
+ 2. TEST: Query and verify the various componentes of date
+ """
+
+ uri = "tracker:test_date_09"
+ insert = """
+ INSERT { <%s> a nie:InformationElement;
+ nie:informationElementDate "2004-05-06T1g:14:15-0200". }
+ """ % (uri)
+ self.sparql_update (insert)
+
+ """ verify the inserted item """
+
+ query = 'SELECT ?s fn:year-from-dateTime (?v) \
+ fn:month-from-dateTime (?v) \
+ fn:day-from-dateTime (?v) \
+ fn:hours-from-dateTime (?v) \
+ fn:minutes-from-dateTime (?v) \
+ fn:seconds-from-dateTime (?v) \
+ fn:timezone-from-dateTime (?v) \
+ WHERE { ?s a nie:InformationElement; \
+ nie:informationElementDate ?v . \
+ }'
+ result = self.query (query)
+
+ for i in range(len(result)):
+ if result[i][0] == 'tracker:test_date_09':
+ if result[i][1] == '2004' and result[i][2] == '05' and result[i][3] == '06' and result[i][5] == '14' and result[i][6] == '15' and result[i][7] == '-9000':
+ self.assert_(True,'Pass')
+ else:
+ print result[i]
+ self.fail('Fail %s' %result)
+
+
+
+
+""" Deletion test cases """
+class s_delete(TestUpdate):
+
+ def test_delete_01(self):
+
+ ''' Insert triples and Delete a triple. Verify the deletion with a query'''
+
+ """first insert """
+ self.sparql_update('INSERT {<urn:uuid:7646001> a nco:Contact; \
+ nco:fullname "Artist_1_delete". \
+ <file:///media/PIKKUTIKKU/5000_songs_with_metadata_and_album_arts/Artist_1/1_Album/11_song_del.mp3> a nmm:MusicPiece,nfo:FileDataObject;\
+ nfo:fileName "11_song_del.mp3"; \
+ nfo:genre "Classic delete"; \
+ nmm:musicAlbum "1_Album_delete"; \
+ nmm:performer <urn:uuid:7646001>.}')
+
+ """verify the insertion """
+ self.verify_test_insert_delete_01()
+
+ """now delete """
+ self.sparql_update('DELETE { \
+ <file:///media/PIKKUTIKKU/5000_songs_with_metadata_and_album_arts/Artist_1/1_Album/11_song_del.mp3> nfo:genre "Classic delete".}')
+ print " After deleting a triple"
+ """verify the deletion """
+ self.verify_test_delete_01()
+
+
+ def verify_test_insert_delete_01(self):
+ result = self.query('SELECT ?fname ?genre WHERE { \
+ ?songfile nfo:fileName ?fname ;\
+ nfo:genre ?genre .\
+ FILTER (?genre = "Classic delete") \
+ }')
+ if result != []:
+ for i in range(len(result)):
+ if result[i][0] == '11_song_del.mp3':
+ if result[i][1] == "Classic delete":
+ self.assert_(True,'Pass')
+ else:
+ self.fail('File not inserted, so failing the \'Delete genre \' testcase')
+ else:
+ self.fail('File not inserted, so failing the \'Delete genre \' testcase')
+
+ def verify_test_delete_01(self):
+
+ result = self.query('SELECT ?fn WHERE { \
+ ?f a nmm:MusicPiece . \
+ ?f nfo:fileName ?fn ;\
+ nfo:genre ?genre .\
+ FILTER (?genre = "Classic delete") \
+ }' )
+
+ if result != []:
+ for i in range(len(result)):
+ if result[i][0] == '11_song_del.mp3':
+ self.fail('Fail %s' %result)
+ else:
+ self.assert_(True,'Pass')
+ else:
+ self.assert_(True,'Pass')
+
+
+ def test_delete_02 (self):
+
+ """Delete a MusicAlbum and count the album """
+ """
+ 1. add a music album.
+ 2. count the number of albums
+ 3. delete an album
+ 2. count the number of albums
+ """
+
+ """Add a music album """
+ self.sparql_update('INSERT {<06_Album_delete> a nmm:MusicAlbum;\
+ nmm:albumTitle "06_Album_delete".}')
+
+ """get the count of music albums"""
+ result = self.query('SELECT ?album WHERE { \
+ ?album a nmm:MusicAlbum. \
+ } ')
+ count_before_del = len(result)
+ print len(result)
+ print result
+
+
+ """Delete the added music album """
+ #self.sparql_update('DELETE { \
+ #<6_Album_delete> a nmm:MusicAlbum.}')
+
+ """get the count of music albums"""
+ result = self.query('SELECT ?album WHERE { \
+ ?albuumm a nmm:MusicAlbum. \
+ } ')
+
+ count_after_del = len(result)
+ print len(result)
+
+ self.assertEquals (count_before_del - 1, count_after_del)
+
+
+""" Batch Update test cases """
+class s_batch_update(TestUpdate):
+
+ def test_batch_insert_01(self):
+ """batch insertion of 100 contacts:
+ 1. delete those existing contacts which we want to insert again.
+ 2. insert 100 contacts.
+ 3. delete the inserted contacts.
+ """
+
+
+ """delete those existing contacts which we want to insert again.
+ the uid creation is same here as it's created during insertion."""
+
+ for j in range(100) :
+ uid = j*1000+1234
+ delete = 'DELETE {?contact a rdfs:Resource} WHERE {?contact nco:contactUID <%s> }' %uid
+ self.sparql_update (delete)
+
+ """ querry no. of existing contacts. """
+ result = self.query ('SELECT ?c ?Fname ?Gname ?number WHERE { \
+ ?c a nco:PersonContact ; \
+ nco:nameGiven ?Gname ; \
+ nco:nameFamily ?Fname; \
+ nco:hasPhoneNumber ?number. \
+ } LIMIT 1000')
+
+ count_before_insert = len(result)
+ print "contact count before insert %d" %count_before_insert
+
+ """insert 100 contacts."""
+ INSERT_SPARQL = "; ".join([
+ "<%s> a nco:PersonContact",
+ "nco:nameGiven '%s'",
+ "nco:nameFamily '%s'",
+ "nco:contactUID %s",
+ "nco:hasPhoneNumber <tel:%s>."
+ ])
+ a="\n"
+ """Preparing a list of Contacts """
+ for j in range(100) :
+ contact= str(random.randint(0, sys.maxint))
+ names1=['christopher','paul','timothy','stephen','michael','andrew','harold','douglas','timothy','walter','kevin','joshua','robert','matthew','broderick','lacy','rashad','darro','antonia','chas']
+
+ names2=['cyril','ronny','stevie','lon','freeman','erin','duncan','kennith','carmine','augustine','young','chadwick','wilburn','jonas','lazaro','brooks','ariel','dusty','tracey','scottie','seymour']
+ firstname=random.choice(names1)
+ lastname=random.choice(names2)
+ contactUID= j*1000+1234
+ PhoneNumber= str(random.randint(0, sys.maxint))
+ sparql_insert=INSERT_SPARQL % (contact,firstname,lastname, contactUID,PhoneNumber)
+ a=a+sparql_insert
+ INSERT= "INSERT{" + a + "}"
+
+ self.resources.BatchSparqlUpdate(INSERT)
+
+ """ querry no. of existing contacts. """
+ result = self.query ('SELECT ?c ?Fname ?Gname ?number WHERE { \
+ ?c a nco:PersonContact ; \
+ nco:nameGiven ?Gname ; \
+ nco:nameFamily ?Fname; \
+ nco:hasPhoneNumber ?number. \
+ } LIMIT 1000')
+
+ count_after_insert = len(result)
+ print "contact count after insert %d" %count_after_insert
+
+ """ cleanup the inserted contacts """
+ for j in range(100) :
+ uid = j*1000+1234
+ delete = 'DELETE {?contact a rdfs:Resource} WHERE {?contact nco:contactUID <%s> }' %uid
+ self.sparql_update (delete)
+
+ """test verification """
+ if count_after_insert == 1000:
+ if count_after_insert >= count_before_insert:
+ self.assert_(True,'Pass')
+ else:
+ self.fail('batch insertion failed')
+ else:
+ if count_after_insert == count_before_insert + 100:
+ self.assert_(True,'Pass')
+ else:
+ self.fail('batch insertion failed')
+
+
+
+
+
+if __name__ == "__main__":
+ unittest.main()
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]