(More coming) |
No edit summary |
||
(8 intermediate revisions by the same user not shown) | |||
Line 8: | Line 8: | ||
** Short-term things to tackle for Fedora 13 | ** Short-term things to tackle for Fedora 13 | ||
* The Board wants the Fedora Project to be a hospitable environment for people who want to pursue goals outside this vision | * The Board wants the Fedora Project to be a hospitable environment for people who want to pursue goals outside this vision | ||
== Possibly agreed? == | |||
* The Board understands that specific engineering and release management changes should be coordinated with FESCo; the Board sets the goal, FESCo implements | |||
== Target audience == | == Target audience == | ||
Line 36: | Line 39: | ||
* They have a general knowledge of computers, have installed software in some manner before, are comfortable with basic computer terms like RAM, CPU, gigabyte, etc. | * They have a general knowledge of computers, have installed software in some manner before, are comfortable with basic computer terms like RAM, CPU, gigabyte, etc. | ||
|- | |- | ||
|} | | notting || | ||
We should have a single default spin/release/whatever that puts our best foot forward for a specific use case, allowing us to attract more people to Fedora, some portion of which will then join the project as contributors. In order to be able to sanely grow the | |||
community around it, that default should be somewhat fixed - what the default is shouldn't be changing from release to release. As for 'target user'... the stock answer is the computer-literate user who wants a coherent, easy-to-use system that doesn't get in their way. We don't necessarily want to target all the way down to the user who's never used a computer before, but I think attempting to target only those who have Linux experience, or are already tinkerers, is too limiting. I feel this default should be something like the desktop spin; a clean interface targeted at a wide variety of users that can be easily extended for a large number of use cases. | |||
|- | |||
| poelstra || | |||
* moderately experienced computer users who wants to use Linux as a desktop (email, web surfing, office suite, software development) or to run simple web services | |||
** they should not have to go to the command line to fix problems that come up due to bad package updates or other unintended egressions | |||
* comfortable installing a new operating system themselves to a stand-alone machine (no dual boot or other craziness--wipe the whole drive and continue) | |||
* someone interested in going deeper and learning more about how the operating system works | |||
|- | |||
|} | |||
== Vision for Distribution == | == Vision for Distribution == | ||
Line 58: | Line 71: | ||
* Evolution. Continuing to showcase the latest stable FOSS and trying to provide a great experience out of the box. | * Evolution. Continuing to showcase the latest stable FOSS and trying to provide a great experience out of the box. | ||
* Consistent methodolgy in place for how we treat released versions of the distro in terms of updates, bug fixing, etc. Consistency across the distro is going to help users gauge what to expect. | * Consistent methodolgy in place for how we treat released versions of the distro in terms of updates, bug fixing, etc. Consistency across the distro is going to help users gauge what to expect. | ||
* Pick a spin and focus primary development on that. To a large degree, we have started down this path already with the webpage | * Pick a spin and focus primary development on that. To a large degree, we have started down this path already with the webpage redesigns, the reaffirmation that the desktop spin is our default, etc. This is not to say that there can't be other spins, or that we don't want Fedora to allow people to produce derivations. However I do feel that treating them all as equals and using terms like 'first among equals' is a disservice to the distro overall. A tiered approach provides clarity. | ||
redesigns, the reaffirmation that the desktop spin is our default, etc. This is not to say that there can't be other spins, or that we don't want Fedora to allow people to produce derivations. However I do feel that treating them all as equals and using terms like 'first among equals' is a disservice to the distro overall. A tiered approach provides clarity. | |- | ||
| notting || | |||
*Produced images to be: | |||
** the default Fedora distribution as described above (could be a LiveCD spin) | |||
** the netinst/rescue iso | |||
** the spins | |||
*Without a specific target audience, the current Fedora tree should go. | |||
*Standard set of distribution tests so that when we compose a new livecd/spin/tree, we can, in an automated fashion, get a large variety of results quickly as to how well it works | |||
* 'israwidebroken.com' to resoundingly respond 'no' 95% of the time. | |||
|- | |||
| poelstra || | |||
* Our release processes are running smoothly and more people understand how they work--no last minute "I didn't realize Feature Freeze meant my feature had to be mostly done." | |||
* Our releases ship on time and we do not miss any of our test or final release dates | |||
** if we do, it is for something other than, blocker bugs weren't fixed in time or rawhide wasn't working | |||
* The release under development is destabilized far less than it is today | |||
** "unfrozen rawhide" is fully implemented and the main branch release under development is stable and can be reverted to (thus allowing us to ship on time) when regressions or other bugs are introduced | |||
** in a given month rawhide was installable and usable for regular desktop use 90% of the time. | |||
* The question of who our target audience is or what the Fedora distro is for are answered and established. | |||
** When these topics come up they are discussed in form of "we should change from X to Y" not "how about X or Y or why do we need to decide?". | |||
|- | |||
|} | |} | ||
Line 81: | Line 113: | ||
* More education efforts for users (extending the Fedora Classroom ideas, writing content on how to do things, etc.) | * More education efforts for users (extending the Fedora Classroom ideas, writing content on how to do things, etc.) | ||
* Less aversion to looking at other distros and reusing/contributing to things they have started that are beneficial to Fedora. | * Less aversion to looking at other distros and reusing/contributing to things they have started that are beneficial to Fedora. | ||
|- | |||
| notting || | |||
* Metrics wise, an increase in contributors (hopefully across the board) | |||
* Development-wise, more actual development discussion on the devel list; patches, code review, feature proposals/discussion, etc. | |||
* An increase in task-focused spins. Right now, the focus of many of our spins appears to be i-want-a-desktop-too-but-not-that-desktop, which doesn't necessarily expand the use cases that people can hit with Fedora as much. | |||
|- | |||
| poelstra || | |||
* Wider integration and use of the community portal | |||
** Establish a clearer vision of who this portal is for and what how it will be used by more people | |||
** Actively use and take advantage of it | |||
** I know the portal does a lot of cool things, but I'm not sure who its intended audience is | |||
* We can accurately answer questions like (beyond just counting FAS accounts): | |||
** Is community participation growing or slowing? | |||
** Is the Fedora Project attracting new people? | |||
*** Are they staying? | |||
*** What makes them stay? | |||
*** How involved are they? | |||
*** What is causing them to leave? | |||
* The Fedora Project is known as a welcoming software community that helps other people grow. | |||
** It is considered the "gold standard" for how well run open source software projects work. This same standard is also applied to the way we create our distro and how it is received by our targeted audience. | |||
** We have an established way to measure this | |||
|} | |} | ||
Line 106: | Line 159: | ||
* A clear process around the creation of the distribution. I think rel-eng is making strides towards this already, and trying to improve the experience for contributors with no frozen rawhide and auto-qa. I'd like to see us support that and invest in it because it will have a wide benefit. | * A clear process around the creation of the distribution. I think rel-eng is making strides towards this already, and trying to improve the experience for contributors with no frozen rawhide and auto-qa. I'd like to see us support that and invest in it because it will have a wide benefit. | ||
* Easy one: auto-sign builds. Represent signed packages exactly as they are today: Fedora built this. That's it. Signing doesn't imply it's been tested or QA'd or that it is somehow a known quantity. It simply means the package as built by Fedora. | * Easy one: auto-sign builds. Represent signed packages exactly as they are today: Fedora built this. That's it. Signing doesn't imply it's been tested or QA'd or that it is somehow a known quantity. It simply means the package as built by Fedora. | ||
|- | |||
| notting || | |||
* QA QA QA. AutoQA doing automated tests, AutoQA mailing those test results to developers for review, AutoQA using those tests to block packages where necessary, AutoQA using those tests to promote packages where necessary. A database of past test results so we know what broke, when. | |||
* Defined policy around updating and maintaining released distributions. Not being able to concisely explain what sort of updates you get is a problem. | |||
* Set up a mechanism where large changes can be built in koji, set up as a repo, and tested sanely before being merged, ideally as a self-serve mechanism. | |||
|- | |||
| caillon || | |||
# Define a list of core/critical-path functionality that packagers are required to ensure they do not break. Define a plan of action for what happens if such functionality becomes broken. See example[1]. Bonus points: come up with an easy to follow "smoketest" for how to determine whether something on the list is broken. | |||
# Define update criteria for our release streams: what types of updates we expect, and what types of updates we do not want in each stream. Define a plan of action for what happens if an update fails to comply. See example[2]. | |||
# Set up something similar to Mozilla's "Sheriffs"[3]. The Sheriff will be a rotating role and shall be responsible for coordination and enforcing of the previous two rules. If an issue arises, the sheriff will attempt to contact the packager responsible, and attempt to get them to fix or revert the issue. If this isn't possible within 15 minutes, the sheriff will find a provenpackager to do so. | |||
# Improve our test suites. Provide $coolstuff incentive for people who contribute (the most?) valid test cases. | |||
# Start an initiative to automate as much of the above as possible. Possibly as GSoC projects. Particularly, I'd like to see a tinderbox which creates VMs from a buildroot+ks file, runs automated tests for the critical path, and outputs the PASS/FAIL results. I'd also like to have a post-commit hook which reminds people to not break stuff and to be available to the sheriff on IRC. | |||
[1] Example: Core/critical-path is a system must boot up, get a display manager with XYZ video cards, be able to log in successfully, be able to get a working network via ethernet (and if available, via xyz wireless cards), have audio work on XYZ audio cards, and be able to successfully use yum/rpm/PackageKit. In the event any package breaks this functionality, the package must be fixed immediately (within 15? minutes of noticing) or the changed is reverted, package untagged and rebuilt. If N violations occur, provenpackager status is revoked. | |||
[2] Example: For rawhide, do not break dependencies without announcing in advance about why you are doing so to fedora-devel-list, and not receiving objections. For Fedora releases, updates must not break ABI or dependencies without getting an exception granted from FESCo. In the event any package fails to comply, the change is immediately reverted, and mail sent to the packager owner. If N violations occur, provenpackager status is revoked. | |||
[3] https://wiki.mozilla.org/Sheriff_Duty | |||
|- | |||
| poelstra || | |||
# Completely (as in nothing deferred to Fedora 14) implement the "unfrozen rawhide" proposal | |||
# Update our documented release process and freeze policies so that more people can understand them and find them | |||
#* I'm planning to help with this one. Ideas on how to measure the success or failure of this is welcome. | |||
# More communication about upcoming schedule milestones and what the expectations are around those milestones | |||
#* I'm planning to help with this one. Ideas on how to measure the success or failure of this is welcome. | |||
# Release Criteria for each release: Alpha, Beta, and Final | |||
#* I'm planning to help with this one. | |||
#* in order to write good release criteria we need to know what the goals are for what we are creating and releasing | |||
#* To to this we also have be able define what success is for our releases. | |||
#* I'm suggesting something beyond what we have now and have some drafts in progress | |||
# Clear instructions and a guide so that anyone can write a test for the automated QA testing framework. Established processes for adding newly written tests to the framework and seeing the results. | |||
# The automated testing framework tells us more often than not when rawhide is unusable on a particular day vs. someone discovering it on their own. A place for fedora-test-list posters to check first. | |||
|} | |} |
Latest revision as of 05:25, 22 October 2009
Agreed
- The Board owns issues concerning defining project-wide vision.
- The Board will resolve the following issues by the end of FUDCon in December 2009:
- Target audience
- Vision for Fedora Project by mid-2011 (F15)
- Vision for Fedora 15
- Short-term things to tackle for Fedora 13
- The Board wants the Fedora Project to be a hospitable environment for people who want to pursue goals outside this vision
Possibly agreed?
- The Board understands that specific engineering and release management changes should be coordinated with FESCo; the Board sets the goal, FESCo implements
Target audience
Member | Statement |
---|---|
mmcgrath | Experienced users and people that wish to aid in leading our industry through contribution, experimentation and science. (inventors, tinkerers, hackers) |
pfrields | In terms of characteristics or approach, this person:
In terms of skills and knowledge, this person:
Clearly this person is not a developer, but including this person in our target audience does not disadvantage developers as end-users of the distribution. Focusing on this person's needs might mean that we the Fedora community might have to come up with better strategies for delivering software, or re-examine our release processes, or develop some new ways of creating the distribution/tree so that we can allow developers to maintain a high pace where appropriate, yet not have that boomerang on all users. |
jwboyer |
|
notting |
We should have a single default spin/release/whatever that puts our best foot forward for a specific use case, allowing us to attract more people to Fedora, some portion of which will then join the project as contributors. In order to be able to sanely grow the community around it, that default should be somewhat fixed - what the default is shouldn't be changing from release to release. As for 'target user'... the stock answer is the computer-literate user who wants a coherent, easy-to-use system that doesn't get in their way. We don't necessarily want to target all the way down to the user who's never used a computer before, but I think attempting to target only those who have Linux experience, or are already tinkerers, is too limiting. I feel this default should be something like the desktop spin; a clean interface targeted at a wide variety of users that can be easily extended for a large number of use cases. |
poelstra |
|
Vision for Distribution
Member | Statement |
---|---|
mmcgrath |
|
pfrields |
|
jwboyer |
|
notting |
|
poelstra |
|
Vision for Project
Member | Statement |
---|---|
mmcgrath |
|
pfrields |
|
jwboyer |
|
notting |
|
poelstra |
|
F13 Fix Points
Member | Statement |
---|---|
mmcgrath |
|
pfrields |
|
jwboyer |
|
notting |
|
caillon |
[1] Example: Core/critical-path is a system must boot up, get a display manager with XYZ video cards, be able to log in successfully, be able to get a working network via ethernet (and if available, via xyz wireless cards), have audio work on XYZ audio cards, and be able to successfully use yum/rpm/PackageKit. In the event any package breaks this functionality, the package must be fixed immediately (within 15? minutes of noticing) or the changed is reverted, package untagged and rebuilt. If N violations occur, provenpackager status is revoked. [2] Example: For rawhide, do not break dependencies without announcing in advance about why you are doing so to fedora-devel-list, and not receiving objections. For Fedora releases, updates must not break ABI or dependencies without getting an exception granted from FESCo. In the event any package fails to comply, the change is immediately reverted, and mail sent to the packager owner. If N violations occur, provenpackager status is revoked. |
poelstra |
|