This landing repo as meant as a the best starting place to get a coherent view of how information is organised in this GitHub organization.
WIP.
This is the set of key repos that
Repo | Description | Maintainer |
---|---|---|
substrate-runtime-joystream | The Joystream substrate runtime. | @mnaamani |
substrate-node-joystream | The Joystream substrate node. | @mnaamani |
apps | The Pioneer application. | @siman |
storage-node-joystream | The storage node application. | @jfinkhaeuser |
whitepaper | The Joystream whitepaper. | @bedeho |
communications | The Joystream communications workspace and archive. | @@bwhm |
Until the Joystream mainnet goes live, a sequence of test networks will be rolled out and deployed, and this section covers this activity.
Sparta
Network | Started | Ended | Release Plan |
---|---|---|---|
Sparta | x | NA | NA |
Mesopotamia | x | x | NA |
The reason this is placed in public view on Github is two fold
Open Invitation: Serve as an open invitation for anyone who wants to learn, comment and possibly contribute, to the current or future development of the Joystream project.
Best Practices: Establish best practices which can be replicated by the platform, when it is fully live, in how to collaboratively build and manage the platform using open tools. In particular, the current plan is that the platform has a built in Github equivalent, which thus would allow the use of these conventions.
Meeting itineraries are prepared on a case by case basis, depending on the context, and a template for this, as well as an index of archived itineraries, can be found here.
Project management is primarily centred around planning and tracking OKRs. OKRs is a planning and project management system, which can be reviewed in further detail here.
A key result can be assigned to a mix of people or other objectives. The assignment set of a key result consitutes the set of relevant actors, directly or indirectly - for OKRs, that are working to satisfy the result. Each assignment is given a weight from 0 to 1, and the total weight across an assignment set is 1. Some key results, in particular for very higher order OKRs, may not have assignments at all times.
The OKRs can be classified into two separate families of types, first
Project OKRs: Project OKRs can run over multiple years and are graded very rarely. They contain the root objectives that require no deeper justification. Every other objective must be justified directly, or indirectly through another key result, by virtue of its relevance to the project OKRs. The current set of such OKRs can be found below.
Quarterly OKRs: Every quarter, new OKRs for the given quarter are derived, referred to as quarterly OKRs. Only OKRs which have independent objectives are formally referred to as quarterly OKRs, any derivative OKR is not, even if derived at the start of a quarter. Importantly, they should contain very little detail about releases. The current set of such OKRs can be found below.
Release OKRs: Releases are planned one after the other on a rolling basis, and the release OKRs correspond to a single release. Only OKRs which have independent objectives are formally referred to as release OKRs, any derivative OKR is not, even if derived at in the context of a release. The current set of such OKRs can be found below
and then second
Group OKRs: Group OKRs are defined by the set of stakeholders assigned to the key results, and in particular that there is more than one person involved. Typically this could be a set of people working as a team on some topic or problem. In principle, such an OKR can be rationalised by a mix of release and quarterly OKRs, but in practice it will most often just be one or the other. These OKRs should be flexible in time scope, and should be reorganized if circumstances change. The current set of such OKRs can be found below.
Personal OKRs: The exact same thing as group OKRs, only applying to a single person only. The current set of such OKRs can be found below.
Note: Any OKR from the first family is
never a personal OKR, even if assigned to a single person
never a group OKR, even if assigned to a multiple persons
The following figure attempts to summarise how these OKR families and types are related, and their relevant temporal scopes.
All OKRs, except the project OKR, should be derived, in terms of its objective, from one or more key results of already existing higher order OKRs.
In order to keep track of whether a key result, and thus the corresponding objective, will in the end be satisfied, forecasts are tracked throughout the lifetime of an OKR. Each OKR has its own periodic tracking of progress, and to compute the its forecasted value, do as indicated in the example figure below.
Briefly, do a topological sort of the key result graph, where having an objective in the result assignment set counts towards the indegree. Then just do ascending weighted averaging of scores, where key results are simply averaged into objective scores. Importantly, in order to do this, one has to get personal scores on key results, and there are two modes of doing this
Naive: Simply evaluate the key result statement directly based on available data at the time. For example, if the result is Get $100 in revenue
, and one has $20 so far, then the score would be 0.2. This method is often suitable, but no if partial work is unlikely to have had any real world effects while tracking.
Planned Work Done: Fraction of estimated total hours required that have been completed. This means that, if the estimate of total time required changes, then the score can change, even there is not change in actual hours completed.
The mode used depend on the nature of the key result.
The schema used for recording and tracking OKRs has the following form:
<Name of objective>
<When the final grading is conducted>
<Time interval at which OKR is tracked>
<Name of person responsible for doing tracking, at given interval, and final grading>
<If all key results have same assignment set, write here>
<Statement of Key result>
<Name of assignee>
: <assignment weight>
Date | KR #1 | ... | Total |
---|---|---|---|
<date&time> |
(<... assignment set scores> ) Total KR score |
... | Tracked objective score |
All releases have the following branding materials, which should be summarised in a markdown Branding Document
All releases should have a corresponding release directory in the /testnets
directory of this repo, and it should have the following structure
RELEASE_NAME
README.md
: Release document.specification.md
: Testnet speficiation./branding
: A directory which includes a branding document and related assets, as described in the branding section/tutorials
: User facing tutorials for participating on the network.Each release is directed by a Release Manager (RM) who is responsible for
A release plan will consist of a set of projects, each with a corresponding lead, these are referred to as the leads.
The specification lead is responsible for moving the specification process forward, and the committee is anyone who is expected to contribute.
WIP: we need to connect this to broader information about our specification work, but that is not done yet
First release meeting, should take no more than 45 minutes, with agenda
Second release meeting, should take no more than 90 minutes, with agenda
Third release meeting, should take no more than 90 minutes, with agenda
If feasible, then proceed with
Open ended technical meetings which are conducted iteratively with implementing out parts of the release.
This whole process should take no more than X days from start to finish, and involves the following sequence of events and corresponding deadlines.
The following must be determined no later than the day before the prior testnet release.
TESTNET_NAME
RM shall have done the following no later than at the day after the prior testnet release.
created PR establishing a new testnet directory, where
TESTNET_NAME
initiated creation of possibly missing logomark
scheduled a meeting time for the launch meeting no later than the next available working day when all core contributors are available.
create a subdirectory of the meeting directory that has itinerary with appropriate agenda
Conduct launch meeting.
After the meeting is over, the RM shall on the same day have the testnet directory pull request merged with completed itinerary.
Leads must complete their user stories contributions, in the form of PRs into the meeting directory, before the user stories meeting starts.
Conduct user stories meeting.
After the meeting is over, the RM shall have the lead pull requests merged, with possible modifications, no later than the day after.
Leads must complete their release plan sections, in the form of PRs into the meeting directory, before the release plan finalisation meeting starts.
Conduct release plan finalisation meeting.
After the meeting is over, the RM shall on the same days
create a github project per release objective on the Joystream Github Organisation which kanban boards with standardized columns: TODO
, In progress
, Done
and Halted
.
update release document link to relevant github projects.
updates the label set to reflect any new possible products
Specification work begins, and is scheduled and organised on an ad-hoc basis. Anyone unaffected by this work can continue to move forward immediately.
Leads must convert their release plan contributions into tangible tasks, in the form of github issues on the relevant github project created. After this process, the release plan itself should no longer be consulted, also if changes are made.
Release planning meetings are conducted on a per-need basis, typically more frequently as the release date approaches.
WIP: describe how we use github, in particular