Roadmap

Background: In recent years, Wikimedia Foundation's engineering planning has primarily taken place in a combination of internal goals documents and public project-level documentation. The purpose of this page is to establish a practice of sharing holistic engineering goals, initially primarily with a short term horizon, as a public document with open participation. See also: Previous months:
 * Product Whitepaper for Wikimedia Foundation product priority justifications; Strategic Plan for long-term WMF  goals, some of which are engineering goals
 * Roadmap/Archive for an earlier effort to create a roadmap more focused on point releases of the MediaWiki software
 * /2011/September
 * /2011/October
 * /2011/November
 * /2011/December
 * /2012/January
 * /2012/February
 * /2012/March
 * /2012/April
 * /2012/May
 * /2012/June
 * /2012/July

Item syntax: Examples:
 * Project name
 * [Qualifier keyword] Action item [Owner(s)] [Completion keyword]
 * New unicorn engagement
 * [Needs consensus] Deploy unicorns [Brion/Tim]
 * Deploy unicorns [Brion/Tim] [DONE]

Continuous Responsibilities

 * Code review
 * RT review / ops tasks
 * Community extension review and deployment
 * Bug triages and general bug fixes
 * New extension deployment (Review queue)
 * Labs maintenance
 * Test infrastructure maintenance
 * Recruitment and encouragement of volunteers
 * Monthly report and other engineering communications

Technical Operations

 * Deploy Memcached @TAMPA [Mark/Asher/Leslie] - delayed (networking cable issues)
 * Provision Memcached servers @ EQIAD [RobH} - [done]
 * Swift
 * Move to new 404 handler (Aaron/Ben) [DONE]
 * Cutover Originals (multi-media) on Swift - Tampa [Aaron/Ben/Faidon/Ariel]
 * Write new originals to Swift [DONE]
 * Reads from Swift with NFS as backup [ongoing, deployed to test*, mw.org] [DONE]
 * upgrade Tampa Swift cluster to 1.5 from 1.43 [Faidon/Ariel]  - [DONE]
 * build up Eqiad Swift - [DONE]
 * Fundraising infrastructure buildup@ EQIAD [Jeff G]
 * provision and deploy Boron (build host) - [Done]
 * provision and deploy Indium (logging host) - [Done]
 * build pxeboot, preseed, and puppet config - [Done]
 * provision payment hosts - [Done]
 * provision pay-lvs hosts - [Done]
 * deploy nagios-nsca monitoring for new hosts - [Done]
 * Limited Apache-on-Precise deployment @ Tampa [Asher/Peter/Mark] - [Done]
 * NetApp /home deployment [Mark] - [Done]
 * Labs OpenStack release upgrade [Ryan/Faidon] - [Done]
 * Install new passive optics system between the 2 datacenters in Tampa
 * CWDM Optics to increase bandwith capacity [DONE]
 * Varnish
 * deploy Varnish with persistent store [Mark] [testing on mobile] - [done]

Mobile / Offline

 * Transition to the team to using Mingle [DONE]
 * Release beta1 WLM App [DONE]
 * Release beta2 WLM App [DONE]
 * Release beta3 WLM App [DONE]
 * Release V1.1Final WLM App to market
 * Message out to community [DONE]
 * Create marketing materials [DONE]
 * Deploy WMF WLM API server [DONE]
 * Turn on GeoData for test wiki [DONE]
 * Continue Zero testing with new mobile partner [DONE]
 * Continue SMS/USSD testing with new mobile partner [DONE]


 * Evaluate additional features
 * Mobile Article Feedback feature definition [Phil]
 * Minor Editing [Phil]
 * New Zero Launches

Visual Editor

 * VisualEditor
 * API (implementation of 3 features) [IN PROCESS]
 * Feature implementation and bugfixing on VE according to 3 month plan [IN PROCESS]
 * Parsoid
 * Parsoid fixes for release (December date) [ONGOING]
 * Assessment of C/C++ implementation of Parsoid [IN PROCESS]

(other) Editor Engagement

 * New Pages Feed (fka Page Triage)
 * Public soft launch of curation toolbar feature (link on Special:NewPages, curation toolbar by default): [DONE]
 * Other potential changes to be prioritized (e.g., message to article author, visual changes to New Pages Feed, etc.) [DONE]
 * Keyboard shortcuts: spec [IN PROCESS]
 * Increase visibility of Special:NewPagesFeed (e.g., notice on Special:NewPages) [DONE]
 * Additional socialization [ONGOING]


 * Article feedback
 * Add feedback pages to watchlist [DONE]
 * assessment of scalability issues surrounding AFTv5 [DONE]
 * performance/db related changes to AFTv5 queries before scaling [IN PROCESS]
 * bugfixing and small feature enhancements [DONE]
 * Other issues for enwp release (mobile, etc.)
 * Link with page protection [IN PROCESS]


 * Echo_(Notifications) & Flow
 * Deployment of prototype for Mediawiki.org [Werdna/Vibha] [DONE]
 * UI and bugfixing of Echo [ONGOING]
 * see Performance engineering and Database Sharding for prep work on Echo & Flow


 * E3
 * Clicktracking/Analytics
 * E3 analytics, Clicktracking re-design [IN PROGRESS]
 * Post-edit Feedback
 * Data analysis [IN PROGRESS]
 * Community Portal on en.wp
 * Enabling clicktracking on Community Portal page on en.wp [DONE]
 * UX improvements for Community Portal page on en.wp [DONE]
 * Account Creation User Experience
 * UI/UX mockups [IN PROGRESS]
 * Development [IN PROGRESS]
 * Clicktracking enablement - first iteration [DONE]

Multimedia

 * UploadWizard
 * One sprint devoted to UploadWizard bugs for WLM [Kaldari/Holmquist] [IN PROCESS]

Support

 * ResourceLoader 2 -- mostly the Gadgets-extension work which is (as of June 2012) in a branch.
 * Set up a first working setup in WMF labs [Roan, Timo] [IN PROCESS]
 * Testing existing gadgets on WMF labs for breakage [Timo] [IN PROCESS]
 * Discussion of global scripts hosting [IN PROCESS]


 * Fundraising Engineering
 * Auditing and Reconciliation (expect to complete mid-late August) [DONE]
 * Adding Amazon payment processor [DONE]
 * Adding Adyen payment processor [IN PROGRESS]

i18n & R/D

 * Internationalization/Localization
 * Universal Language Selector
 * Version 1 development [IN PROGRESS]
 * User Experience / UI testing [ONGOING]
 * Technical documentation [TBD]
 * Project Lassi: Translate UX Improvements
 * User Experience / UI testing [IN PROGRESS]
 * Prototype development [IN PROGRESS]
 * Translate API
 * API definition [On Hold]
 * TTMServer
 * Labs setup of SOLR review [DONE]
 * Testing of SOLR / TTMServer [DONE]
 * Deployment to 7 wikis [IN PROGRESS]
 * Web Fonts
 * Adding languages [ONGOING]
 * Narayam
 * Adding input methods for other languages [ONGOING]
 * Project Milkshake
 * Design specification, API specification, development [IN PROGRESS]
 * Technical documentation [TBD]
 * Language search
 * Initial analysis [DONE]
 * Prototype initial concept [IN PROGRESS]
 * Integration into ULS [IN PROGRESS]

MediaWiki Core

 * Lua scripting
 * Deploy to test2 [DONE]
 * Deploy to mediawiki.org [DONE]
 * MediaWiki 1.20/Roadmap
 * Bi-weekly deployment cycle continues
 * 1.20wmf9 [DONE]
 * 1.20wmf10 [DONE]
 * Continuous integration
 * On hold in August
 * Git/Conversion [Chad/Antoine]
 * Finalize decision on Gerrit vs other tools [Brion, David, Chad] [DONE]
 * Improvements to project listing screen upstream [DONE]
 * Research current Lucene status upstream & begin pressing on that [Chad]
 * Create build environment so we can deploy custom builds [IN PROGRESS]
 * Overhaul puppet config for gerrit and get labs functioning [IN PROGRESS]
 * SwiftMedia
 * See "Swift" section in Ops
 * OAuth
 * Finalize specifications, identify/recruit developers [ChrisS] [on hold]
 * Admin tools development
 * CentralAuth and AbuseFilter bugfixing [Chris Steipp] [ongoing]
 * Global AbuseFilter rules [Chris Steipp] [ongoing]
 * Global AbuseFilter variables/throttling [Chris Steipp]
 * CentralAuth mass account blocking [Chris Steipp] (possibly September)
 * Site performance
 * Assessment of PHP 5.4 and suhosin removal [DONE] [Tim/Faidon/Asher]
 * Ready to move to PHP 5.4 when Ops is ready
 * Incremental architectural improvements
 * Category collation
 * Pt wiki fix ready for deployment by Tim - window scheduled for Tuesday, August 21 [DONE]
 * Database sharding
 * Initial prototype work (Aaron/Asher/Matthias) [IN PROGESS]
 * Awaiting review by Tim
 * Wikidata deployment
 * Code review of extensions [Sam, Tim] [ongoing]

QA

 * Start helping test NewPagesFeed/Page Curation Toolbar [Chris] [DONE,ONGOING]
 * Enable and configure useful extensions on beta labs (AFTv5, NewPagesFeed, Curation Toolbar, etc.) for testing [Antoine/Chris][IN PROGRESS] (final step, deploying to beta via Jenkins/git was waiting on gluster upgrade)
 * possible Sept test event for PageTriage/NewPagesFeed/Curation Toolbar [Chris][IN PROGRESS] (final decision by Aug 17)
 * miscellaneous projects as required: EtherEdit testing, TMH testing, documentation, small projects [ONGOING]
 * Hiring for QA Engineer, Bug Wrangler and Volunteer Eng Coordinator

Analytics

 * Cache Server Log Aggregation Plan [Dave, Otto] [IN PROGRESS]
 * Complete testing Kafka
 * Complete architectural suggestions document
 * Present to Ops, get signoff, throw party
 * Hire new engineer [DONE] (announcement pending)
 * Prototype of Data Warehouse [Dave, Otto] [pending]
 * Test CDH4 on Cassandra 1.x
 * Test DSE

Engineering Community Team

 * Bug Wrangling [Bug Wrangler + volunteers]
 * Activate Tech Ambassadors Network [Guillaume]
 * Google Summer of Code wrapup [Sumana]
 * Planning events [Sumana]
 * Hiring

Technical Operations

 * Deploy Memcached @TAMPA [Mark/Asher/Leslie]
 * Wide Apache-on-Precise test deployment @ Tampa [Asher/Peter/Mark]
 * complete packaging, puppetising and testing of Image-Scalers @ Tampa [Peter/Mark/Faidon]
 * Limited ImageScalers-on-Precise deployment @ Tampa [Asher/Peter/Mark]
 * Swift
 * Full switch-over (disable NFS) [ongoing]
 * Complete Eqiad Swift replication [RobH / Faidon / Ariel]
 * complete migration of the rest of contents from ms7 to Swift [Aaron]
 * Fundraising infrastructure buildup@ EQIAD [Jeff G]
 * migrate services (logging, puppet, deployment system) from silicon to boron/indium
 * move silicon to frack, re-image to provision/test activemq
 * deploy ganglia for new cluster
 * test/tune/deploy new payments infrastructure
 * document new infrastructure
 * Varnish
 * deploy Varnish with persistent store [Mark] [testing on mobile]
 * deploy Varnish with fixes to streaming video performance issues [Mark]
 * Provision & Deploy Poolcounter servers@eqiad
 * Eqiad Deployment Host
 * Provision
 * migrate from tampa

Mobile / Offline

 * Polish for WLM App
 * Begin backlog planning for new nav

Visual Editor

 * VisualEditor
 * API (implementation of 3 features) [IN PROCESS]
 * Feature implementation and bugfixing on VE according to 3 month plan [IN PROCESS]
 * Parsoid
 * C++ implementation of Parsoid [IN PROCESS]
 * Parsoid fixes for release (December date) [ONGOING]

(other) Editor Engagement

 * New Pages Feed (fka Page Triage)
 * Public launch of New Pages feed [mid Sept]
 * Keyboard shortcuts: spec [IN PROCESS]
 * Additional socialization [ONGOING]
 * Final features (metrics)
 * Descriptive statistics on NPF [Dario] [IN PROCESS]
 * Additional socialization and public announcement/launch
 * Article Creation Wizard: TBD
 * Article feedback
 * performance/db related changes to AFTv5 queries before scaling, + sharding (see Database sharding) [IN PROCESS]
 * (new features TBD pending scalability issues)
 * Other issues for enwp release (mobile, etc.)
 * Link with page protection [IN PROCESS]
 * Echo_(Notifications) & Flow
 * re-deployment of prototype for Mediawiki.org [Werdna/Vibha] [IN PROCESS]
 * UI and bugfixing of Echo [ONGOING]
 * Next set of features TBD
 * (see Performance engineering for infrastructure prep work:)
 * queueing & Echo
 * Database Sharding & Flow

Editor Engagement Experimentation

 * E3
 * Clicktracking/Analytics
 * E3 analytics, Clicktracking re-design [IN PROGRESS]
 * Post-edit Feedback
 * Data analysis [IN PROGRESS]
 * Community Portal on en.wp
 * Account Creation User Experience
 * UI/UX mockups [IN PROGRESS]
 * Development [IN PROGRESS]
 * Development [IN PROGRESS]

Multimedia

 * UploadWizard
 * One sprint devoted to UploadWizard bugs for WLM [Kaldari/Holmquist] [DONE]
 * Integration of Flickr GSoC work (requires operational infrastructure change) [COMPLETE/BLOCKED]
 * TimedMediaHandler
 * Bugfixing of player on test2 [IN PROCESS]
 * Deployment of transcoding boxes
 * Possible work on writing transcodes exclusively to Swift
 * Create production deployment plan

Support

 * ResourceLoader 2 -- mostly the Gadgets-extension work which is (as of June 2012) in a branch.
 * Testing existing gadgets on WMF labs for breakage [Timo] [IN PROCESS]
 * "Gadgets 3.0": Includes getting a version deployed/integrated, then a review of Salvatore's "Gadgets user  preferences" work, then a merge of Salvatore's work


 * Fundraising Engineering
 * Add Adyen payment processor [IN PROCESS]
 * Refactor PayPal, Moneybookers processors [IN PROCESS]

MediaWiki Core

 * Memcache client replacement
 * Deploy memcache client to Apaches (RT 3155) - possibly blocked on Precise deployment to eqiad
 * Configuration change (to be scheduled)
 * Git/Conversion (Chad/Antoine)
 * Upgrade to 2.5
 * Mirror mediawiki-core to GitHub (waiting on Gerrit 2.5) [Chad]
 * Have last of extensions out of SVN and into Git
 * Have Lucene work underway upstream for 2.6 release cycle
 * Finish replicating all repos to GitHub
 * Begin researching how to get pull requests back in
 * Have gitweb replacement in place (probably GitBlit)
 * OAuth
 * Discuss at tech days/all staff [ChrisS]
 * Swift
 * See Swift section in Ops
 * MediaWiki 1.20/Roadmap
 * Bi-weekly deployment cycle continues
 * 1.20wmf11
 * 1.20wmf12
 * Continuous integration
 * Admin tools development
 * Wikidata deployment
 * Code review of extensions [Sam, Tim]
 * Site performance

QA

 * use beta cluster hosting latest version of prod extensions (AFTv5, NewPagesFeed, etc.) for testing [Antoine/Chris] [IN PROGRESS]
 * engaged with all Features testing [CHRIS] [ONGOING]
 * contractor at work(?) [IN DISCUSSION]

Analytics

 * Cache Server Log Aggregation Plan [Dave, Otto] [IN PROGRESS]
 * Complete testing Kafka
 * Complete architectural suggestions document
 * Present to Ops, get signoff, throw party
 * Hand off Limn to new engineer [Dave] [pending]
 * Prototype of Data Warehouse [Dave, Otto] [pending]
 * Test CDH4 on Cassandra 1.x
 * Test DSE

Engineering Community Team

 * GSoC wrapup & postmortem [Sumana + volunteers]
 * Bug Wrangling [Bug Wrangler + volunteers]
 * Online or in-person QA trainings for the community [Volunteer Engineering Coordinator]
 * Preparation for upcoming events [Sumana]
 * Tech Ambassadors Network [Guillaume]
 * Volunteer product management program [Guillaume]

i18n/L10n

 * Internationalization/Localization
 * Universal Language Selector
 * Version 1 development [IN PROGRESS]
 * User Experience / UI testing [ONGOING]
 * Technical documentation [TBD]
 * Project Lassi: Translate UX Improvements
 * User Experience / UI testing [IN PROGRESS]
 * Prototype development [IN PROGRESS]
 * Translate API
 * API definition [On Hold]
 * TTMServer
 * Labs setup of SOLR review DONE
 * Testing of SOLR / TTMServer DONE
 * Deployment to 7 wikis IN PROGRESS
 * Web Fonts
 * Adding languages [ONGOING]
 * Narayam
 * Adding input methods for other languages [ONGOING]
 * Project Milkshake
 * Design specification, API specification, development [IN PROGRESS]
 * Technical documentation [TBD]
 * Language search
 * Initial analysis [DONE]
 * Prototype initial concept [IN PROGRESS]
 * Integration into ULS [IN PROGRESS]

Technical Operations

 * Deploy Memcached @EQIAD [Mark/Asher]
 * Deploy Etherpad Lite [Daniel/RobH]
 * Deploy Mingle [RobH/DZ]
 * Deploy eqiad application serving (Oct 15)

Features

 * New Pages Feed (fka Page Triage)
 * Additional feature development (only must-haves)
 * Article Creation Workflow
 * revisit for release
 * Changes to visual design to make ACW consistent with Design Toolkit
 * Echo_(Notifications)
 * Continued development of prototype for Mediawiki.org [Werdna/Vibha]
 * Global preferences for echo delivery
 * centralization and cross wiki notification delivery

Engineering Community Team

 * India hackathon in the fall? [Sumana, Engineering Outreach Coordinator]
 * UCOSP idea-wrangling
 * Community testing events

Parking lot and todos

 * Install Lua (Scribunto) on other Wikimedia wikis (probably sometime in 2013; see Goals)
 * Category collation
 * Patch waiting on Liangent for more work for full deployment


 * Queuing infrastructure work for Flow (who added this?)
 * Enable $wgHtml5 (bug 27478)
 * Configuration management overhaul [Chad]
 * Evaluate WikiFactory from Wikia
 * Extension management -- depends on config mgmt revamp
 * Details of git migration (extension mgmt, permissions, code review tool, Gerrit-Jenkins integration, etc.)
 * More work on product backlogs for features and mobile
 * Ops section
 * Fundraising flesh-out
 * cf Wikimedia Platform Engineering and merge as appropriate
 * Namespace hacks for development of simple language wikipedias in languages other than English without server, database, or major wiki installation provisioning
 * Most popular related articles
 * Replicated session handling
 * HipHop deployment (deferred because Facebook has a different shiny new thing)
 * Extension:Configure (merge with config management?)
 * Unicode normalization considerations
 * Schema handling improvements (Abstracted database schema description, schema updaters to make the multiple schema variants for MySQL 4.0 and 5/UTF-8 more maintainable)
 * Parallelizable, restartable dump runner (notes; Clean up the currently fragile externaldump process, make our internal backups more reliable
 * OAI cleanup (Clean up OAI exporter and importer, add time-delay features
 * audit users of OAIPMH and check how search indexing uses it
 * Deletion queue system (notes; Human-helpful process improvements
 * Integrated heuristic checks, improved patrolling (human-helpful process improvements)
 * On-wiki namespace manager (Special:Namespaces) (original wikidata branch specs and see notes)
 * Wikidata (WMDE)
 * BlameMaps (WMDE)
 * graphical UI on top of improved backend for configuration management
 * Various HTTPS support fixes
 * Wikimedia server error page
 * Wikimedia operations history and architecture document
 * Disk-backed object cache
 * DB sharding
 * Help features
 * Mentoring features
 * Other real-time features, chat
 * Affiliation tools for WikiProjects [build on GlobalProfile]
 * Gadgets 2.0?
 * Interwiki transclusion
 * WMF cannot commit the time to merge this.
 * Replicated session handling [Tim Starling]
 * Relicense our Lucene contributions [future Lucene search engineer]