Starting g1
Yielded g1 ham
Starting g2
Yielded g2 spam
Finishing g2
Finishing g1
Traceback (most recent call last):
  File "test10.py", line 27, in <module>
    g.throw(e)
  File "test10.py", line 9, in g1
    yield from g2()
  File "test10.py", line 17, in g2
    yield "g2 spam"
ValueError: tomato ejected
