how do I merge multiples data streams key/value?

I want to merge all data stream from N matched IDs across multiples data streams, and duplicate ids append its html_url only , and keep source, and updated_at as one item , but however I am getting only one item with all data from 3 ids when I Have 3 items . so it should be 3 objects with merged with its matching keys/value. what am I missing?

class A:
    def __init__(self):

    def run(self):
        return {"data":[{"id":"ID-2002-0201","updated_at":"2018-05-14T22:25:51Z","html_url":[""],"source":"github"},{"id":"ID-2002-0200","updated_at":"2018-05-14T21:49:15Z","html_url":[""],"source":"github"},{"id":"ID-2002-0348","updated_at":"2018-05-11T14:13:28Z","html_url":[""],"source":"github"}]}

class B:
    def __init__(self):

    def run(self):
        return {"data":[{"id":"ID-2002-0201","updated_at":"2006-03-28","html_url":[""],"source":"sample"},{"id":"ID-2002-0200","updated_at":"2006-06-05","html_url":[""],"source":"sample"},{"id":"ID-2002-0348","updated_at":"2007-03-09","html_url":[""],"source":"sample"}]}
results = {}
data_sources = [A(),B()]
for data in data_sources:
    data_stream =
    for data in data_stream.get('data'):
        for key, value in data.items():
            if key in ['html_url']:
                results.setdefault(key, []).extend(value)
            elif key in ['source']:
                results.setdefault(key, []).append(value)
                results[key] = value