Firefox3/Firefox Requirements
Gran Paradiso Product Planning Doc *DRAFT*
Document History
- 1/1/07 - Wiki-version imported from .doc/.xls working documents (v4a/b from 12/22/06)
- 1/10/07 - Created Functional Requirement (FR)/Non-FR segregation
- 1/17/07 - Revised Cross-cutting concerns section
- 1/19/07 - Added System Requirements, Platform Support, Locale Support sections (deb)
Purpose
This document sets out the feature set, product requirements and prioritization for the development and release of Firefox 3, code-named "Gran Paradiso", presently under development with an expected release in Q3 2007.
The intended audience for this document is the community involved in designing, developing, testing and managing the release of the product as well as partners and third-party developers who are building software that extends Gran Paradiso.
All press inquiries should be directed to the Mozilla Press Center.
Definitions
| Priority | Description | 
| P1 | Mandatory - The set of features required as a minimum for this release to be complete. The product will not ship without these. | 
| P2 | Highly Desirable - A key feature that will make the product more complete, has great benefits to the end-user and major strategic impact. | 
| P3 | Nice to Have - Lowest priority feature that may be incorporated, dropping first in favour of delivering P2 items. | 
| P4 | Future - Intended for future release, included as they may influence design decisions and should be associated with the roadmap. | 
| D | Deleted - Requirements that have been deleted from the product roadmap. | 
| Px | Px - Requirements that are proposed but have not yet been approved. | 
| FR | Functional requirement - Requirements define the internal workings, behavior or functionality | 
| NFR | Non-Functional requirement - Requirements which impose constraints on the design or implementation (such as performance, security, quality standards, or design constraints). | 
Project Documentation
[Image:fx3-doc-tree.png]
[File:Fx3BigFeatures v5.xls]
[File:Fx3ProductPlan v4.doc]
[File:Fx3ProductDetail v1.doc]
Gran Paradiso Plan
Release Objectives
Some of the key goals for Gran Paradiso include:
- Continue to increase usage share and broaden the Firefox audience
- Offer the best user experience
- Remain true to open source, be dedicated to ensuring “choice and innovation”
- Be a platform for community developers, companies and others
- Be the most secure browser choice
Guiding Principles
The goal of the Firefox project is to deliver the best possible browsing experience to the widest possible set of people.
We aim to do this in part by:
- Delivering the right set of features - not too many or too few. (The goal is to create a useful browser, not a minimal browser.)
- Making as few compromises as possible where user experience is concerned. (We will not compromise the main line UI to placate an element of the community.)
- Develop and maintain an extension system to allow for research into new areas without affecting the core and to allow for techies, early adopters, Web developers and other specific communities to customize their browsers to suit their specific needs without affecting usability or download size for the mass market.
- Retaining a tight command and control hierarchy. UI design is not a committee driven process. Application design must be nimble and testing is better than discussion, so we'll make changes quickly and then get them to people so that we can refine them based on observation of "real" user interactions.
- Deliver software for Windows, Mac OS X and Linux, with the goal of integrating as slickly as possible into each of those systems.
- Be, if possible, a vehicle for emerging Mozilla platform APIs including XULRunner, which will allow application developers a means to deploy useful software to people that is not necessarily tied to a particular operating system.
(Adapted from Ben Goodger's Firefox Development Charter, November 28, 2004.)
Audience
There are 4 target sets of users for Gran Paradiso: End Users, Developers, Distributors and Enterprise Users. Note that End Users include a variety of personas that should be identified.
Appearing below are value statements for each target user set, in order or priority for this release.
End Users
- For the general consumer
- Who accesses the web
- Firefox is a web browser
- That provides the best user experience
- Unlike Microsoft Internet Explorer, Opera and Apple Safari
- Our product is open, secure, intuitive, customizable, privacy-sensitive and innovative
Developers
- For content producers, software companies and web application developers
- Who want to deliver services and innovate on the web
- Firefox is a web browser with a highly extensible platform
- That provides the most flexible, easy-to-try, standards-compliant? architecture
- Unlike Microsoft Internet Explorer (and associated Windows technologies)
- Our product offers the most open, secure, standards compliant and easy-to-implement environment
Distributors
- For potential distributors such as search engines, portals, ISPs, ISVs, web sites, PC OEMs and companies, member organizations or affinity groups
- Who wish to expand the reach of their services or engage their community
- Firefox is a web browser with flexible customization and distribution capabilities
- That provides the most straightforward, easy-to-use toolkit and business terms
- Unlike Microsoft Internet Explorer/IEAK
- Our product is {TBD}
Enterprise Users
- For the enterprise user
- Who accesses the web
- Firefox is a web browser
- That provides the best user experience from a corporate environment
- Unlike Microsoft Internet Explorer, Opera and Apple Safari
- Our product is the most open, secure, standards compliant, intuitive and innovative browser
Observations & Assumptions
- WebKit may be ported to Windows
- Microsoft will continue to establish deeper ties from IE7/Vista to live.com & MSN
- One or more Web service providers may introduce their own browsing solution that ties to their services
- Opera will continue to operate in a niche environment
Firefox competes because:
- Users and developers love the extensions and customization available for Firefox
- Perception of fast & slim. For AJAX apps, we are faster.
- Perception of security and safety
- WebDev segment love the product for its web compatibility and standards compliance
- Developer tools and support
- Brand value and open source (Participatory culture and community ownership model – by the Web, for the Web)
Release Roadmap
- Issue one major release every year (Fx 3 in 2007, Fx 4 in 2008, etc.) since it helps drive upgrades and adoption
- Target Gran Paradiso for Q3/Q4 2007
- Mozilla 2 will take 2 years to bake and stabilize so target it for Fx 4
- Since Firefox 2 did not include platform upgrades need to get Gecko 1.9/Cairo out the door
- Need approximately one year to help define, build and deliver Gran Paradiso
- First alpha should include at minimum all platform pieces (Gecko, cycle collector, reflow branch, etc.) and selected features
- {Strongly consider} options to do more as incremental updates, e.g. Extension Packs, Fx 2.5, Fx 3.5, etc.
High-Level Feature Plan
The proposed major theme for Gran Paradiso is “improved information and content management” {TODO: needs better wording}. This is the area that we’ll do the most innovation in. Gran Paradiso will continue to improve in areas where we’ve traditionally been strong in: security, usability, extensibility and customization, performance, web standards and compatibility.
Features for Gran Paradiso will fall into one of the following categories.
For Users
- Information Management includes Bookmarks, History, Content Handling, Content Editing, Printing and Microformats
- Security including Privacy, Phishing Protection, Addons and Password Management
- Usability/UI Improvements including Search, Tabbed Browsing, OS Integration & Accessibility
- Customization - ability to discover and manage addons
- Performance - how fast Firefox operates
- Localization - operating in non US English
- Installation & Auto-Update
- Support & Help
For Developers
- Web Standards & Compatibility (e.g. ACID2, CSS2.1, SVG via Gecko 1.9, EV certs, etc.)
- Web Developer Tools
- Extension Developer Tools
For Distributors
- Browser Customization
For Enterprises
- {Selected at-par features}
System Requirements
These requirements are not final and are subject to change pending review.
Windows
- Minimum System Requirements
- 233 Mhz processor
- 64 MB of RAM
- 50 MB of free disk space
- Microsoft Windows 98
 
- Mozilla Recommends
- 500 Mhz processor
- 256 MB of RAM
- 100 MB of free disk space
- Microsoft Windows XP
 
Mac
- Minimum System Requirements
- PowerPC G3 processor
- 128 MB of RAM
- 75 MB of free disk space
- Mac OS X 10.2.x
 
- Mozilla Recommends
- PowerPC G4 or Intel processor
- 512 MB of RAM
- 150 MB of free disk space
 
Linux
- Minimum System Requirements
- 233 Mhz processor
- 64 MB of RAM
- 50 MB of free disk space
- Linux kernel 2.2.14 (with glibc 2.3.2, XFree86-3.3.6, gtk+2.0, fontconfig/xft and libstdc++5)
 
- Mozilla Recommends
- 500 Mhz processor
- 256 MB of RAM
- 100 MB of free disk space
- a modern Linux distribution
 
Platform Support
These requirements are not final and are subject to change pending review.
| Platform Support | ||
| Priority | Item | |
| P1 | Windows Vista | |
| P1 | Windows XP | |
| P1 | Windows 2000 | |
| P1 | Windows ME | |
| P1 | Mac OS X 10.2+ (Universal Binary only) | |
| P1 | Red Hat Linux | |
| P2 | All other Linux variants | |
Locale Support
These requirements are not final and are subject to change pending review.
| Priority | Item | |
| Tier 1 | ||
| P1 | English (en-US) | |
| P1 | English (en-GB) | |
| P1 | French (fr) | |
| P1 | German (de) | |
| P1 | Japanese (ja) | |
| P1 | Polish (pl) | |
| P1 | Spanish (es-ES) | |
| Tier 2 | ||
| P1 | Chinese (zh-CN) | |
| P1 | Chinese (zh-TW) | |
| P1 | Czech (cs) | |
| P1 | Danish (da) | |
| P1 | Dutch (nl) | |
| P1 | Finnish (fi) | |
| P1 | Hungarian (hu) | |
| P1 | Italian (it) | |
| P1 | Korean (ko) | |
| P1 | Portuguese (pt-BR) | |
| P1 | Russian (ru) | |
| P1 | Spanish (es-AR) | |
| P1 | Swedish (sv-SE) | |
| P1 | Turkish (tr) | |
| Tier 3 | ||
| P2 | Arabic (ar) - Review | |
| P2 | Basque (eu) - Review | |
| P2 | Belarusian (??) - Review | |
| P2 | Bulgarian (bg) - Review | |
| P2 | Catalan (ca) | |
| P2 | Frisian (fy) - Review | |
| P2 | Georgian (ka) - Review | |
| P2 | Greek (el) - Review | |
| P2 | Gujarati (gu) - Review | |
| P2 | Hebrew (he) - Review | |
| P2 | Irish (ga) - Review | |
| P2 | Kurdish (ku) - Review | |
| P2 | Lithuanian (lt) - Review | |
| P2 | Macedonian (mk) - Review | |
| P2 | Mongolian (mn) - Review | |
| P2 | Norwegian - Bokmål (??) - Review | |
| P2 | Norwegian - Nynorsk (??) - Review | |
| P2 | Portuguese - Portugal (pt-PT) - Review | |
| P2 | Punjabi (??) - Review | |
| P2 | Romanian (ro) - Review | |
| P2 | Slovak (sk) - Review | |
| P2 | Slovenian (sl) - Review | |
| P2 | Spanish - Latin American (es-AR) - Review | |
| P2 | [need to add any highly desirable but would not hold initial release for] | |
Cross-Cutting Concerns & Fundamentals
The following areas were deemed as fundamentals or cross-cutting concerns for all Firefox features. Each feature area should consider impact and orientation with respect to these.
Please conduct the following review for each new or modified feature in Firefox 3. A feature is not considered complete until this review has been finished.
Checklist:
Customization
- Does not interfere with customization options of other features.
- Has all the customization options it needs.
- All customization options are necessary and useful.
- Has been reviewed by the UI/UE team.
Distribution
- Does not impact existing or future Firefox distributions.
- Offers appropriate configuration options for distribution customization.
- Does not need to be more flexible to facilitate custom distributions.
- Has been reviewed by the Distributions team.
Extensibility
- Does not limit or interfere with existing extensibility.
- Adequately supports Add-ons development and extensibility.
- Has been reviewed for extensibility impact and potential.
- Has been reviewed by the XUL/Add-ons team.
Global audience
- Meets all i18n/l10n requirements.
- Has been properly internationalized. Is localizable.
- Has been reviewed by the i18n/l10n teams.
- Does not negatively impact accessibility.
- Has been reviewed by the Accessibility team.
Performance
- Performance metrics have been discussed, agreed upon, and recorded.
- Does not have a negative impact on overall Firefox performance.
- If performance impact is unavoidable, that impact is within a set and agreed upon range.
- Optimized as much as possible to improve overall performance.
- Performance tests have been run and verified by QA.
Privacy
- Does not negatively impact Firefox's privacy features.
- Has been reviewed by the Privacy team.
Reliability/Stability
- Does not negatively impact reliability.
- Has been designed to ensure potential data loss is minimized upon crash or other catastrophic failure.
- Has been reviewed for potential reliability/stability issues.
- Reliability and stability have been reviewed and tested by QA.
Search
- Has been reviewed to absolutely ensure that there is no negative impact on Search features.
- Potential impact on Search has been thoroughly reviewed by the Products team.
Security
- Does not negatively impact existing security features or code.
- Has been reviewed by the Security team.
Testability
- Automated testing is possible.
- Unit tests have been written.
- Sufficient hooks for event synthesis have been added.
Web content compatibility
- Does not negatively impact web content compatibility.
- Does not cause layout regressions. Has passed regression testing.
- Has been reviewed by the Layout team.
Final review
- Has been reviewed by Products team.
- Has been reviewed by UI/UE team.
- Has been fully tested by QA.
Detailed Feature Plan
Functional Requirements & Tasks
S/M/L indicate rough engineering estimate of difficulty and work required, in order to aid in planning.
P1/MANDATORY Features
- Improve Add-On install experience
- FR: Add-On can be installed in fewer than 3 mouse clicks
- NFR: simplify XPI Install dialogs and user interactions
- NFR: simplify user interaction with whitelist
 
- Improve Add-On configuration experience
- FR: allow Add-On configuration UI to be accessed from main application configuration UI
- NFR: improve discoverability of Add-On configuration UI
 
- Improve Add-On management experience
- FR: add visual indication when Add-On Updates are present to browser UI
- FR: add permanent button for restarting firefox
- FR: expose all hidden functionality such as "Find Update"
- NFR: improve usability of Add-On Manager
- NFR: simplify language and unify terminology
 
- Provide an extensible bookmarks back-end platform
- FR: ability to synchronize bookmarks with remote service
- FR: generic annotation system for extensibility
- FR: protection and safeguarding against data loss
- FR: improve search, retrieval and startup performance
- FR: allow users to annotate bookmarks and history
- NFR: usable and robust API for extensibility
 
- Improve content handling, add support for web services to act as content handlers
- FR: support web services as MIME type handlers
- FR: remove local MIME type database for local applications
- NFR: simplify content handling UI
- NFR: easy to use configuration of MIME type handling in application configuration UI
 
- Robust plugin support for Flash, Acrobat, WMV, Quicktime, Java
- FR: should be able to play all popular media formats when plugins/codecs are installed
- FR: embedded rich content areas should function when plugins are installed
- FR: missing plugins should be able to be located and installed
- NFR: plugin crashes should not crash the entire application
 
- Improved Printing Support
- FR: pages should break without dividing paragraphs
- FR: print layout should look like rendered layout
- FR: preview should look like print layout
- FR: layout should be zoomed/cropped to fit desired page size
- NFR: simpler print preview dialog
- NFR: printed material should match user expectations
 
- Provide MSI install bundle (Windows only)
- FR: build system should create .msi bundle
 
- Improve Password Manager, add identity management
- FR: support Microsoft CardSpace
- FR: support OpenID
- FR: do not offer to remember passwords when login fails
- FR: store more precise URIs for autofilling userIDs and passwords
- NFR: simple identity management configuration UI
- NFR: compatibility with OS level identity management options
- NFR: improve usefulness of password manager
- NFR: improve usability of autofill UI
 
- Security / Privacy Context UI redesign (the lock icon sucks; needs more detail)
- FR: support website identity validation mechanism (ref: EV Certificates)
- FR: indicate security and privacy status in secondary UI
- FR: alert user when they are providing information on a suspicious website
- NFR: user should be able to determine "identity" of website when that information is available
- NFR: user should be able to investigate signals of website trustworthiness
- NFR: better UI indication of encryption, identity, previous interaction/knowledge of site, overall level of trust in site
 
- Airbag
- FR: collect crash stack data and report to central server
- NFR: improve usability of crash report UI
 
- Improve the user support environment from beginning to end
- FR: support reporting multiple types of problems through reporter
- NFR: make it easier for users to solve their problems and engage with our support community
- NFR: make it easier to get rapid feedback on problems being encountered by our users
 
P2/HIGHLY DESIRABLE Features
- Improve password security for users
- FR: generate hashed passwords for increased security (ref: psswdhash)
- NFR: as usable as normal password management/entry
 
- Private web browsing
- FR: create a "private browsing mode" for Firefox
- FR: indicate privacy status, exchange of personal information in primary UI
- NFR: should not interfere with normal browsing mode
 
- Web page archiving
- FR: save web pages as PDF documents
- FR: integrate with user history to allow for easy retrieval
 
- Blacklisting of malicious web sites
- FR: extend Phishing Protection to include malware sites and Add-Ons
- NFR: unify terminology and metaphors for "blocked malicious content"
 
- Improve download handling across multiple sessions
- FR: support pause/resume for downloads
 
- Microformat detection framework
- FR: create document parsing framework for detecting microformats
- FR: create API for developers to leverage this framework
 
- Microformat handling
- FR: display microformats in content area
- FR: allow user to configure microformat handlers
- FR: support hCard, hCal and geo
- FR: provide API/data formats for adding additional microformat types
- FR: allow web developers to override microformat display attributes
- NFR: must not affect page load time
 
- Support for third-party identity management systems
- FR: provide extensible identity management API
 
- Move Help content to web
- FR: remove client-side documentation and replace with links to online documentation
 
P3/NICE TO HAVE Features
- Unified bookmark/history/subscription manager
- FR: tbd
- NFR: unified user interface that improves usability and discoverability of features
 
- Extended download history management
- FR: unclear
- NFR: easier retrieval of files that a user has downloaded in the past
- NFR: simplified (non-modal?) UI for managing downloads
 
- Keychain integration (Mac OS X only)
- FR: integrate password management with Keychain
 
- Full text indexing and search in user history
- FR: index web page content into DB that can be queried
- FR: provide UI for querying DB
- NFR: history search should also use full text indexes to generate results
 
- Install Add-Ons without interrupting browsing session
- FR: install Add-On without requiring browser restart
 
- Web Page Archiving
- FR: store web page content for later retrieval and viewing
- NFR: integrate with history for easy retrieval
 
- Context sensitive help
- NFR: help topics should be immediately relevant to users
 
- Handling of back/forward with POST
- FR: cache data from source of POST request
- FR: return to cached data when going back/forward across POST requests
- NFR: get rid of the "Do you want to resend the request dialog?"
 
- Out-of-band login support
- ??
 
- Support one-time search engine use
- FR: ability to declare a default search engine
- FR: ability to use a temporary search engine and then restore default
- NFR: easy to understand control mechanism
 
- Vista Parental Controls support (Windows only)
- FR: integrate with Windows Vista parental controls
 
- Tab Grouping
- NFR: quickly group like tabs together
 
- Tab Expose
- NFR: quickly find the tab you're looking for
 
- Windows Group Policy support
- NFR: allow IT Administrators to create group profile policies
 
LARGE UI REDESIGN AREAS
- ? - UI re-design: Extension Install
- ? - UI re-design: Password / Identity Manager
- ? - UI re-design: Security/Privacy Context
- ? - UI re-design: Bookmarks Manager
- ? - UI re-design: Download Manager
Non-functional Requirements & Tasks
- Peformance evaluation and test suite
Investigation
Needs Immediate Investigation for Scoping/Definition
- Low Rights Mode (probably not feasible) (need to find out about feasibility and decide if this is Moz1.9 or Moz2)
- Identity Management and how it may intersect with Password Management
- Define minimum requirements for Airbag
- Define minimum requirements for "improving the support environment"
- Define minimum requirements Privacy/Security context UI
Pending Evaluation
- Add-on Security model
- Ability to discover add-ons, ease of adoption, supportability
- Form content mgmt, loss prevention
- Revised Security Context UI
- Revised First Run Experience
- Showcase breadth of ways to show all customization
- TTS/Screenreader support
- Cairo interaction - visual momentum
Appendix 1 - Big Feature List
| Target | Category | Functional Area | Priority | 
| End User | Addons | Improve addon install experience | P1 | 
| End User | Addons | Improve preference management for addons | P1 | 
| End User | Addons | Revised Addons management | P1 | 
| End User | Bookmarks | Revised Bookmark Manager | P2 | 
| End User | Bookmarks | Extensibility platform (with sync support) | P1 | 
| End User | History | Revised History Solution | P2 | 
| End User | Content Handling | Config UI for application integration | P1 | 
| End User | Content Handling | Fx be able to display common content such as Flash, Acrobat, Java, WM | P1 | 
| End User | Printing | Revise printing experience | P1 | 
| End User | Installation & Auto-Update | Vista-compatibility for installation | P1 | 
| End User | Privacy | Private browsing mode | P1 | 
| End User | Phishing Protection | Add Malware protection | P2 | 
| End User | Addons | Addons Security | P2 | 
| End User | Security | Low Rights Mode | P2 | 
| End User | Addons | Ability to discover addons | P2 | 
| End User | Content Handling | Snapshoting or hiving of pages | P3 | 
| End User | Content Handling | Revised Download Manager | P2 | 
| End User | Content Editing | Form content management, prevent loss | P2 | 
| End User | Microformats | Detect & display microformats | P2 | 
| End User | Microformats | Configure application handlers for microformat data | P2 | 
| End User | Localization | Ensuring all critical areas of browser are localization-ready | P1 | 
| End User | Password & Identity Mgmt | Revised Password Manager | P1 | 
| End User | Password & Identity Mgmt | Identity Mgmt solution, e.g. OpenID, CardSpace | P2 | 
| End User | Security | Revised Security Context UI | P2 | 
| End User | Stability | Airbag | P2 | 
| End User | Support & Help | New support mechanism and help system | P2 | 
| End User | Usability/UI Improvements | Revised First Run Experience | P2 | 
| End User | Customization | Showcase breadth of ways to show all customizations | P3 | 
| End User | Parental Controls | Parental Controls Support | P3 | 
| End User | Support & Help | Context Sensitive | P3 | 
| End User | Support & Help | Help should be hosted | P2 | 
| End User | Search | Enhancement to Search | P3 | 
| End User | Tabbed Browsing | Enhancements to Tabbed Browsing | P3 | 
| End User | Accessibility | TTS/Screenreader support | P3 | 
| End User | Visual Playfulness | Cairo inteactions - visual momentum | P3 | 
| Developers | Web Standards & Compatibility | CSS 2.1 | P2 | 
| Developers | Web Standards & Compatibility | SVG/Canvas | P2 | 
| Developers | Web Standards & Compatibility | Gecko 1.9 for standards support and room for performance improvements | P2 | 
| Developers | Web Standards & Compatibility | Reflow branch for xxxx | P2 | 
| Developers | Web Standards & Compatibility | Layout mods (roc) for xxxx | P2 | 
| Developers | Web Standards & Compatibility | EV Certs | P2 | 
| Developers | Web Standards & Compatibility | Cairo mods for better more native MacOS look and feel | P2 | 
| Developers | Web Developer Tools | Add new microformat detectors | P3 | 
| Developers | Web Developer Tools | Register new microformat handlers | P3 | 
| Developers | Web Standards & Compatibility | ACID 2 | P3 | 
| Distributors | Browser Customization | Lock in branding, cannot uninstall | P2 | 
| Distributors | Browser Customization | Smooth upgrade while retaining branding customizations | P2 | 
| Enterprises | Installation & Auto-Update | Windows MSI package support | P2 | 
| Enterprises | Management | Windows Group Policy support | P2 | 
Please do not edit these pages without permission of the Gran Paradiso steering group. Your feedback and comments are welcomed on the discussion page.
Milestones
| Milestone | Description | 
| A1 | 3.0a1 - Gran Paradiso Alpha 1 | 
| A2 | 3.0a2 - Gran Paradiso Alpha 2 | 
| B1 | 3.0b1 - Gran Paradiso Beta 1 | 
| B2 | 3.0b2 - Gran Paradiso Beta 2 | 
Note: Milestone targets are included in this document for initial planning purposes, authoratative landing targets will continue to be held per individual bug, and the latest tracking status for each feature area will be listed in the most recent status meeting minutes.