2

我有一些测试可以与 pyethereum 创建合同并用它们做各种事情,但我对如何获取有关它们记录的事件的信息感到困惑。

一个简化的例子:

from ethereum import tester as t

s = t.state()
code = """contract LogTest {
            event LogMyNumber(uint);

            function LogTest() {
            }

            function logSomething() {
                LogMyNumber(4); 
            }
        }"""

logtest = t.state().abi_contract(code, language='solidity', sender=t.k0)
logtest.logSomething()

#number_i_logged = WHAT DO I DO HERE?
#print "You logged the number %d" % (number_i_logged)

我运行它并得到:

No handlers could be found for logger "eth.pow"
{'': 4, '_event_type': 'LogMyNumber'}

正在打印的 json 是我想要的信息,但是有人可以解释或指出一个示例,说明我如何捕获它并将其加载到 python 中的变量中,以便我可以检查它并用它做些什么?似乎有一个名为 log_listener 的东西可以传递给 abi_contract ,看起来它是相关的,但我不知道该怎么处理它。

4

1 回答 1

3

我知道你已经等待了很长时间的答案,但如果其他人想知道,这里是:你提到的 log_listeners 是要走的路。您可以在pyethereum 的测试中找到一些使用它的示例代码,这是您的固定代码:

from ethereum import tester as t

s = t.state()
code = """contract LogTest {
            event LogMyNumber(uint loggedNumber);

            function LogTest() {
            }

            function logSomething() {
                LogMyNumber(4);
            }
        }"""

c = s.abi_contract(code, language='solidity', sender=t.k0)
o = []
s.block.log_listeners.append(lambda x: o.append(c._translator.listen(x)))

c.logSomething()

assert len(o) == 1
assert o == [{"_event_type": 'LogMyNumber', "loggedNumber": 4}]

number_i_logged = o[0]["loggedNumber"]
print "You logged the number %d" % (number_i_logged)
于 2016-02-10T09:28:05.073 回答