Skip to content

Commit

Permalink
fix error when finder doesn't honor leaves_only
Browse files Browse the repository at this point in the history
  • Loading branch information
DanCech committed Nov 30, 2017
1 parent 61ac7f2 commit 6182d86
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 4 deletions.
4 changes: 4 additions & 0 deletions webapp/graphite/finders/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
import time
import abc

from graphite.node import BranchNode, LeafNode # noqa
from graphite.util import is_pattern
from graphite.intervals import Interval

Expand Down Expand Up @@ -129,6 +130,9 @@ def fetch(self, patterns, start_time, end_time, now=None, requestContext=None):
result = []

for node, query in self.find_multi(queries):
if not isinstance(node, LeafNode):
continue

time_info, values = node.fetch(
start_time, end_time,
now=now, requestContext=requestContext
Expand Down
19 changes: 15 additions & 4 deletions webapp/tests/test_storage.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,10 @@
class StorageTest(TestCase):

def test_fetch(self):
disabled_finder = DisabledFinder()
legacy_finder = LegacyFinder()
test_finder = TestFinder()
remote_finder = RemoteFinder()
disabled_finder = get_finders('tests.test_storage.DisabledFinder')[0]
legacy_finder = get_finders('tests.test_storage.LegacyFinder')[0]
test_finder = get_finders('tests.test_storage.TestFinder')[0]
remote_finder = get_finders('tests.test_storage.RemoteFinder')[0]

store = Store(
finders=[disabled_finder, legacy_finder, test_finder, remote_finder],
Expand All @@ -43,6 +43,17 @@ def test_fetch(self):
result = store.fetch([], 1, 2, 3, {})
self.assertEqual(result, [])

# fetch
result = store.fetch(['a.**'], 1, 2, 3, {})
self.assertEqual(len(result), 3)
result.sort(key=lambda node: node['name'])
self.assertEqual(result[0]['name'], 'a.b.c.d')
self.assertEqual(result[0]['pathExpression'], 'a.**')
self.assertEqual(result[1]['name'], 'a.b.c.d')
self.assertEqual(result[1]['pathExpression'], 'a.**')
self.assertEqual(result[2]['name'], 'a.b.c.e')
self.assertEqual(result[2]['pathExpression'], 'a.**')

def test_fetch_pool_timeout(self):
# pool timeout
store = Store(
Expand Down

0 comments on commit 6182d86

Please sign in to comment.