This repo is for determing solutions to large initiatives that require significant preparation, discussion, and planning, particularly those with multiple divirgent potential solutions. The process:
If you're blocked, have questions, or are unsure about how to proceed, message @grin on Slack.
The issue description should contain the following items:
The first step of every team is to make a strong effort on building a consensus problem statement and user stories.
Ideally, this should be completed on the first meeting. If issues are raised on this meeting that require further research or discovery to form the problem statement, these tasks should be assigned. Then, another meeting should be had after those tasks are completed. This process should be repeated until the problem statement and user stories are well formed.
If there is no consensus on the problem and no further research or discovery actions, disagreements on the problem should be noted. Maybe the issue needs to be split into two or more separate problems.
At this point, the issue should include the well-defined problem statement, well-defined requirements, and well-defined user stories, be tagged "prepared", and converted to an epic.
At times, a problem may have trade-offs between requirements (e.g. it may not be possible for a solution to be both decentralized and performant). In these cases, this should be noted on the issue.
A tentative deadline should be set for submitting proposed solutions.
After the problem is prepared, anyone can submit a proposed solution. Members of the problem group may submit solutions on their own, form subgroups to work on different solutions, or all work together on separate solutions.
When a proposal is ready to accept solutions, announce this fact to everyone.
Proposed solutions should include:
Proposed solutions should be attached to the epic representing the problem and be tagged "solution".
As soon as a proposed solution is in a state where feedback can be given, it should be shared with the rest of the group either via chat or email. All members of the group are encouraged to collaborate on others solutions, both in terms of pointing out problems and improvements.
Remember: the goal is not to have your own solution "win", but to find the best overall solution.
After the solution deadline and group members have submitted potential solutions, a meeting should be set to present all potential solutions in real time to all group members, as well as the CTO and CEO.
On or shortly after this meeting, one of two things will happen: