mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-12 05:02:32 +01:00
RSS: Use an explicit timeout for assertNoResponse, because it defaults to 0.
Which means there may be a command/update thread running and returning after assertNoResponse returns. In particular, that's an issue when assertNoResponse is called right before setting feedparser._open_resource, because the running thread might still be holding the lock but have fetched the new version already, so the thread announces the new feed elements earlier than expected.
This commit is contained in:
parent
a4665803fa
commit
dcf55cf6de
@ -117,7 +117,7 @@ class RSSTestCase(ChannelPluginTestCase):
|
|||||||
with conf.supybot.plugins.RSS.initialAnnounceHeadlines.context(0):
|
with conf.supybot.plugins.RSS.initialAnnounceHeadlines.context(0):
|
||||||
self.assertNotError('rss add xkcd http://xkcd.com/rss.xml')
|
self.assertNotError('rss add xkcd http://xkcd.com/rss.xml')
|
||||||
self.assertNotError('rss announce add xkcd')
|
self.assertNotError('rss announce add xkcd')
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
finally:
|
finally:
|
||||||
self._feedMsg('rss announce remove xkcd')
|
self._feedMsg('rss announce remove xkcd')
|
||||||
self._feedMsg('rss remove xkcd')
|
self._feedMsg('rss remove xkcd')
|
||||||
@ -135,10 +135,9 @@ class RSSTestCase(ChannelPluginTestCase):
|
|||||||
with conf.supybot.plugins.RSS.sortFeedItems.context('oldestFirst'):
|
with conf.supybot.plugins.RSS.sortFeedItems.context('oldestFirst'):
|
||||||
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
self.assertNoResponse(' ')
|
|
||||||
feedparser._open_resource = constant(xkcd_new)
|
feedparser._open_resource = constant(xkcd_new)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertRegexp(' ', 'Chaos')
|
self.assertRegexp(' ', 'Chaos')
|
||||||
self.assertRegexp(' ', 'Telescopes')
|
self.assertRegexp(' ', 'Telescopes')
|
||||||
@ -161,10 +160,10 @@ class RSSTestCase(ChannelPluginTestCase):
|
|||||||
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
||||||
with conf.supybot.plugins.RSS.maximumAnnounceHeadlines.context(1):
|
with conf.supybot.plugins.RSS.maximumAnnounceHeadlines.context(1):
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
self.assertNoResponse(' ')
|
|
||||||
feedparser._open_resource = constant(xkcd_new)
|
feedparser._open_resource = constant(xkcd_new)
|
||||||
self.assertNoResponse(' ')
|
log.debug('set return value to: %r', xkcd_new)
|
||||||
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertRegexp(' ', 'Telescopes')
|
self.assertRegexp(' ', 'Telescopes')
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ')
|
||||||
@ -182,10 +181,9 @@ class RSSTestCase(ChannelPluginTestCase):
|
|||||||
self.assertNotError(' ')
|
self.assertNotError(' ')
|
||||||
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
self.assertNoResponse(' ')
|
|
||||||
feedparser._open_resource = constant(xkcd_new)
|
feedparser._open_resource = constant(xkcd_new)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertRegexp(' ', 'Telescopes')
|
self.assertRegexp(' ', 'Telescopes')
|
||||||
finally:
|
finally:
|
||||||
@ -201,11 +199,11 @@ class RSSTestCase(ChannelPluginTestCase):
|
|||||||
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
||||||
self.assertNotError('rss add xkcd http://xkcd.com/rss.xml')
|
self.assertNotError('rss add xkcd http://xkcd.com/rss.xml')
|
||||||
self.assertNotError('rss announce add xkcd')
|
self.assertNotError('rss announce add xkcd')
|
||||||
self.assertNotError(' ')
|
self.assertNotError(' ', timeout=0.1)
|
||||||
self.assertNotError('reload RSS')
|
self.assertNotError('reload RSS')
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
finally:
|
finally:
|
||||||
self._feedMsg('rss announce remove xkcd')
|
self._feedMsg('rss announce remove xkcd')
|
||||||
self._feedMsg('rss remove xkcd')
|
self._feedMsg('rss remove xkcd')
|
||||||
@ -219,7 +217,7 @@ class RSSTestCase(ChannelPluginTestCase):
|
|||||||
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
with conf.supybot.plugins.RSS.waitPeriod.context(1):
|
||||||
self.assertNotError('rss add xkcd http://xkcd.com/rss.xml')
|
self.assertNotError('rss add xkcd http://xkcd.com/rss.xml')
|
||||||
self.assertNotError('rss announce add xkcd')
|
self.assertNotError('rss announce add xkcd')
|
||||||
self.assertNotError(' ')
|
self.assertRegexp(' ', 'Snake Facts')
|
||||||
feedparser._open_resource = constant(xkcd_new)
|
feedparser._open_resource = constant(xkcd_new)
|
||||||
self.assertNotError('reload RSS')
|
self.assertNotError('reload RSS')
|
||||||
self.assertRegexp(' ', 'Telescopes')
|
self.assertRegexp(' ', 'Telescopes')
|
||||||
@ -257,13 +255,11 @@ class RSSTestCase(ChannelPluginTestCase):
|
|||||||
with conf.supybot.plugins.RSS.initialAnnounceHeadlines.context(1):
|
with conf.supybot.plugins.RSS.initialAnnounceHeadlines.context(1):
|
||||||
with conf.supybot.plugins.RSS.sortFeedItems.context('oldestFirst'):
|
with conf.supybot.plugins.RSS.sortFeedItems.context('oldestFirst'):
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
self.assertNoResponse(' ')
|
|
||||||
self._feedMsg('rss announce remove xkcd')
|
self._feedMsg('rss announce remove xkcd')
|
||||||
feedparser._open_resource = constant(xkcd_new)
|
feedparser._open_resource = constant(xkcd_new)
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
self.assertNoResponse(' ')
|
|
||||||
self.assertNotError('rss announce add xkcd')
|
self.assertNotError('rss announce add xkcd')
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertRegexp(' ', 'Chaos')
|
self.assertRegexp(' ', 'Chaos')
|
||||||
@ -304,16 +300,15 @@ class RSSTestCase(ChannelPluginTestCase):
|
|||||||
with conf.supybot.plugins.RSS.sortFeedItems.context('oldestFirst'):
|
with conf.supybot.plugins.RSS.sortFeedItems.context('oldestFirst'):
|
||||||
with conf.supybot.plugins.RSS.feeds.xkcd1.waitPeriod.context(1):
|
with conf.supybot.plugins.RSS.feeds.xkcd1.waitPeriod.context(1):
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
self.assertNoResponse(' ')
|
|
||||||
feedparser._open_resource = constant(xkcd_new)
|
feedparser._open_resource = constant(xkcd_new)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertRegexp(' ', 'xkcd1.*Chaos')
|
self.assertRegexp(' ', 'xkcd1.*Chaos')
|
||||||
self.assertRegexp(' ', 'xkcd1.*Telescopes')
|
self.assertRegexp(' ', 'xkcd1.*Telescopes')
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ')
|
||||||
timeFastForward(1.1)
|
timeFastForward(1.1)
|
||||||
self.assertNoResponse(' ')
|
self.assertNoResponse(' ', timeout=0.1)
|
||||||
finally:
|
finally:
|
||||||
self._feedMsg('rss announce remove xkcd1')
|
self._feedMsg('rss announce remove xkcd1')
|
||||||
self._feedMsg('rss remove xkcd1')
|
self._feedMsg('rss remove xkcd1')
|
||||||
|
Loading…
Reference in New Issue
Block a user