aboutsummaryrefslogtreecommitdiff
path: root/documentation/content/en/articles/freebsd-status-report-process/_index.adoc
blob: 3193663a13607cde0547e1d33812396fcdcb9770 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
---
title: FreeBSD Status Report Process
authors:
  - author: The FreeBSD Documentation Project
copyright: 2023 The FreeBSD Documentation Project
description: Instructions for both writers and editors of status reports
trademarks: ["freebsd", "git", "github", "general"]
---

= FreeBSD Status Report Process
:doctype: article
:toc: macro
:toclevels: 1
:icons: font
:sectnums:
:sectnumlevels: 6
:source-highlighter: rouge
:experimental:

'''

toc::[]

FreeBSD status reports are published quarterly and provide the general public with a view of what is going on in the Project, and they are often augmented by special reports from Developer Summits.
As they are one of our most visible forms of communication, they are very important.

Throughout this document and in other places related to FreeBSD status reports as well, the expression _status report_ is used both to indicate the document published on a quarterly basis and the single entries that are in it.

== Instructions for writers

This section provides some advice on writing status report entries from mailto:theraven@FreeBSD.org[David Chisnall], experienced in technical writing.
Instructions on how to submit your entries are also given.

_Do not worry if you are not a native English speaker.
The mailto:status@FreeBSD.org[status team] will check your entries for spelling and grammar, and fix it for you._

=== Introduce Your Work

_Do not assume that the person reading the report knows about your project._

The status reports have a wide distribution.
They are often one of the top news items on the FreeBSD web site and are one of the first things that people will read if they want to know a bit about what FreeBSD is.
Consider this example:

....
abc(4) support was added, including frobnicator compatibility.
....

Someone reading this, if they are familiar with UNIX man pages, will know that `abc(4)` is some kind of device.
But why should the reader care?
What kind of device is it?
Compare with this version:

....
A new driver, abc(4), was added to the tree, bringing support for
Yoyodyne's range of Frobnicator network interfaces.
....

Now the reader knows that abc is a network interface driver.
Even if they do not use any Yoyodyne products, you have communicated that FreeBSD's support for network devices is improving.

=== Show the Importance of Your Work

_Status reports are not just about telling everyone that things were done, they also need to explain why they were done._

Carry on with the previous example.
Why is it interesting that we now support Yoyodyne Frobnicator cards?
Are they widespread?
Are they used in a specific popular device?
Are they used in a particular niche where FreeBSD has (or would like to have) a presence?
Are they the fastest network cards on the planet?
Status reports often say things like this:

....
We imported Cyberdyne Systems T800 into the tree.
....

And then they stop.
Maybe the reader is an avid Cyberdyne fan and knows what exciting new features the T800 brings.
This is unlikely.
It is far more likely that they have vaguely heard of whatever you have imported (especially into the ports tree: remember that there are over 30,000 other things there too...).
List some of the new features, or bug fixes.
Tell them why it is a good thing that we have the new version.

=== Tell Us Something New

_Do not recycle the same status report items._

Bear in mind that status reports are not just reports on the status of the project, they are reports on the change of status of the project.
If there is an ongoing project, spend a couple of sentences introducing it, but then spend the rest of the report talking about the new work.
What progress has been made since the last report?
What is left to do?
When is it likely to be finished (or, if "finished" does not really apply, when is it likely to be ready for wider use, for testing, for deployment in production, and so on)?

=== Sponsorship

_Do not forget about your sponsors._

If you or your project has received sponsorship, a scholarship from somebody or you have been already working as a contractor or an employee for a company, please include it.
Sponsors always certainly appreciate if you thank them for their funding, but it is also beneficial for them to show that they are actively supporting the Project this way.
Last, but not least, this helps FreeBSD to learn more about its important consumers.

=== Open Items

_If help is needed, make this explicit!_

Is there any help needed with something?
Are there tasks other people can do?
There are two ways in which you can use the open items part of the status report: to solicit help, or to give a quick overview of the amount of work left.
If there are already enough people working on the project, or it is in a state where adding more people would not speed it up, then the latter is better.
Give some big work items that are in progress, and maybe indicate who is focussing on each one.

List tasks, with enough detail that people know if they are likely to be able to do them, and invite people to get in contact.

=== Submit your report

The following methods are available to submit your reports:

* submit a link:https://reviews.freebsd.org/[Phabricator review] and add the group _status_ to the reviewers list.
You should put your reports in the appropriate subdirectory of `doc/website/content/en/status/` (create it if it is missing);

* submit a pull request to the doc repository through link:https://github.com/freebsd/freebsd-doc[its GitHub mirror] .
You should put your reports in the appropriate subdirectory of `doc/website/content/en/status` (create it if it is missing);

* send an email to status-submissions@FreeBSD.org including your report.

An link:https://www.FreeBSD.org/status/report-sample.adoc[AsciiDoc sample report template] is available.

== Instructions for editors

This section describes how the reviewing and publication process works.

[.informaltable]
[cols="1,1", frame="none"]
|===

|Status reports main webpage
|link:https://www.FreeBSD.org/status/[https://www.FreeBSD.org/status/]

|Status reports archived GitHub repository (was used for reports from 2017Q4 to 2022Q4):
|link:https://www.github.com/freebsd/freebsd-quarterly[https://github.com/freebsd/freebsd-quarterly]

|Main status team email address
|link:mailto:status@FreeBSD.org[status@FreeBSD.org]

|Email address for reports submission
|link:mailto:status-submissions@FreeBSD.org[status-submissions@FreeBSD.org]

|Mailing list for receiving calls for status reports
|link:https://lists.freebsd.org/subscription/freebsd-status-calls[freebsd-status-calls@FreeBSD.org]

|Phabricator status team main page
|link:https://reviews.freebsd.org/project/profile/88/[https://reviews.freebsd.org/project/88/]
|===

=== Timeline

Reports are always accepted by the status team, but the main collection process happens the last month of each quarter, hence in March, June, September and December.
Explicit calls for status reports will be sent in those months.
The months of January, April, July and October are dedicated to putting together the reports submitted during the precedent quarter; this can include waiting for late submissions.
Status reports publication is done during the same months as soon as the report are ready.

All report submissions can have the deadline extended by link:mailto:status-submissions@FreeBSD.org[emailing the status team] up until the extended deadline, which is 8 days after the end of the quarter.
Entries from the link:https://www.freebsd.org/administration/#t-portmgr[ports management team] default to the extended headline, because of the overlap between status reports and quarterly ports branches.

Reviewing of submitted reports by people not part of the status team should be essentially complete by mid-January/April/July/October (third-party review slush).
That is, barring typos or other light copyediting, the status team should be able to start assembling the submissions soon after the 15th.
Note that this is not a complete freeze, and the status team may still be able to accept reviews then.

[cols="1,2,2,2,2"]
|===
||First quarter|Second quarter|Third quarter|Fourth quarter

|First call for reports
|March 1st
|June 1st
|September 1st
|December 1st

|2 weeks left reminder
|March 15th
|June 15th
|September 15th
|December 15th

|Last reminder
|March 24th
|June 24th
|September 24th
|December 24th

|Standard deadline
|March 31st
|June 30th
|September 30th
|December 31st

|Extended deadline
|April 8th
|July 8th
|October 8th
|January 8th

|Third-party review slush
|April 15th
|July 15th
|October 15th
|January 15th
|===

=== Call for reports

Calls for status reports are sent to the following recipients:

* the link:https://lists.freebsd.org/subscription/freebsd-status-calls[freebsd-status-calls@FreeBSD.org mailing list];
* to all submitters of last status reports (they may have updates or further improvements);
* and, depending on the season:
	** Various conference organizers:
		*** link:mailto:secretary@asiabsdcon.org[AsiaBSDCon] in March (First Quarter);
		*** link:mailto:info@bsdcan.org[BSDCan] in May (Second Quarter);
		*** EuroBSDcon September - October (Third-Fourth Quarter).
		EuroBSDcon as an organization is not interested in writing reports for FreeBSD (at least it was not in October 2019: its reason is that the conference is not FreeBSD specific), so reports about this event should be asked of members of the FreeBSD community that attended it;
	** Google Summer of Code link:mailto:soc-students@FreeBSD.org[students] and their link:mailto:soc-mentors@FreeBSD.org[mentors].

The easiest way to send calls for status reports is to use the link:https://cgit.freebsd.org/doc/tree/tools/sendcalls/sendcalls[[.filename]#sendcalls# perl script] in the [.filename]#tools/sendcalls# directory of the doc git repository.
The script automatically sends calls to all intended recipients.
It can also be used through a cron job, for example:

....
0      0       1,15,24 3,6,9,12        *       cd ~/doc/tools/sendcalls && git pull && ./sendcalls -s 'Lorenzo Salvadore'
....

[IMPORTANT]
====
If you are in charge of sending calls for status reports and you are indeed using a cron job, please run it on freefall and sign it with your name so that it is possible to infer who has configured the cronjob, in case something goes wrong.
Also please update the example above with your name, as an additional safety measure.
====

It may also be worth making a call for reports on the forums as link:https://forums.freebsd.org/threads/call-for-freebsd-2014q4-october-december-status-reports.49812/[was done in the past].

=== Building the report

Submitted reports are reviewed and merged in the proper subdirectory of [.filename]#doc/website/content/en/status/# as they come in.
While the reports are being updated, people outside the status team may also review the individual entries and propose fixes.

Usually the last step in the content review process is writing the introduction in a file named [.filename]#intro.adoc#: a good introduction can only be written once all the reports have been collected.
If possible, it is a good idea to ask different people to write the introduction to add variety: different people will bring different viewpoints and help keep it fresh.

Once all the reports and the introduction are ready, the [.filename]#_index.adoc# file needs to be created: this is the file in which the reports are distributed into the various categories and sorted.

=== Publishing the report

When all the files of the status report are ready, it is time to publish it.

First [.filename]#doc/website/content/en/status/_index.adoc# is edited: the next due date is updated and a link to the new report is added.
The change is then pushed on the repository and the status team checks that everythings works as expected.

Then the news entry for the main website page is added to [.filename]#doc/website/data/en/news/news.toml#.

Here is a sample for the news entry:
....
[[news]]
date = "2021-01-16"
title = "October-December 2020 Status Report"
description = "The <a href=\"https://www.FreeBSD.org/status/report-2020-10-2020-12.html\">October to December 2020 Status Report</a> is now available with 42 entries."
....

Once the HTML version of the report has been built and is online, man:w3m[1] is used to dump the website as plain-text, e.g:
....
% w3m -cols 80 -dump https://www.FreeBSD.org/status/report-2021-01-2021-03/ > /tmp/report-2021-01-2021-03.txt
....

man:w3m[1] has full proper unicode support. `-dump` simply outputs text rendering of the HTML code that can then have a few elements snipped, while `-cols` ensures that everything is wrapped to 80 columns.

A link to the rendered report is added between the introduction and the first entry.

The report is finally ready to be sent, toggling disposition (the report should be inlined), and ensuring it is encoded as UTF-8.

Two emails are sent, both with subject in the format `FreeBSD Status Report - <First/Second/Third/Fourth> Quarter <year>`:

* one to link:https://lists.freebsd.org/subscription/freebsd-announce[freebsd-announce@FreeBSD.org];

[IMPORTANT]
====
This one must be approved, so if you are in charge of sending this email, ensure that someone does it (mail link:mailto:postmaster@FreeBSD.org[postmaster] if it is taking long).
====

* one to link:https://lists.freebsd.org/subscription/freebsd-hackers[freebsd-hackers@FreeBSD.org], which also has link:https://lists.freebsd.org/subscription/freebsd-current[freebsd-current@FreeBSD.org] and link:https://lists.freebsd.org/subscription/freebsd-stable[freebsd-stable@FreeBSD.org] in CC and `developers@FreeBSD.org` in BCC.