Adds a new ItemStarted event and delivers UserMessage as the first item type (more to come). Renames `InputItem` to `UserInput` considering we're using the `Item` suffix for actual items.
Add `grep_files` to be able to perform more action in parallel
Fix flaky test by warming up the tools
Add parallel tool calls. This is configurable at model level and tool level