Outreachy: Difference between revisions
(Add link for name) |
|||
Line 302: | Line 302: | ||
==== Collaboration Tools for Open Source Participation and Productivity ==== | ==== Collaboration Tools for Open Source Participation and Productivity ==== | ||
Mentor: Don Marti | Mentor: [https://mozillians.org/en-US/u/dmarti/ Don Marti] | ||
We are interested in pushing the limits of what automation can do to help de-stress open source projects, especially low-profile ones that put a lot of work onto an individual maintainer or small team. Interested in writing bots to help maintainers with the routine tasks of software development, bots that can help coach new contributors to get productive, or both? If you have an idea for a collaborative tool that would help you, and you're interested in coding it and seeing if it can help others, please consider joining us. Helpful skills to have | We are interested in pushing the limits of what automation can do to help de-stress open source projects, especially low-profile ones that put a lot of work onto an individual maintainer or small team. Interested in writing bots to help maintainers with the routine tasks of software development, bots that can help coach new contributors to get productive, or both? If you have an idea for a collaborative tool that would help you, and you're interested in coding it and seeing if it can help others, please consider joining us. Helpful skills to have |
Revision as of 00:20, 15 September 2016
Mozilla has participated in the Outreachy program for several years. The goals of the program are to increase participation from under-represented groups in free and open source software. Participation is open:
- internationally to all women (cis and trans), trans men, and genderqueer people
- also open in the U.S. to all Black/African American, Hispanic/Latin@, American Indian, Alaska Native, Native Hawaiian, and Pacific Islander people
We provide a supportive community for beginning to contribute any time throughout the year and offer three month paid contribution opportunities twice a year.
Useful links for More Information
- https://wiki.gnome.org/OutreachProgramForWomen
- https://gnome.org/opw/
- GNOME OPW Handbook
- Information for mentors, from Linux Kernel project
Applications for Round 13 (Dec 2016-March 2017) open Monday September 12
Project List
Make WebExtension Development More Awesome
- Mentor: Kumar McMillan (kumar on IRC)
WebExtensions let anyone extend and customize their web browser, such as blocking ads on every website they visit. This is an exciting time for the API because it’s now possible to write a single extension that works in both Firefox, Chrome, Opera, and soon IE. At Mozilla we provide several tools and resources to make developing extensions fun and easy but we’d like to make this development experience even better.
The participant would improve the productivity of WebExtension developers in the following ways. Most of these tasks involve changing the web-ext command line tool but others may involve writing documentation or example code.
- Utilize common web developer tools when building extensions
- Craft examples that show how to use ES6 imports and other features that typically require code transpilation with babel or rollup
- Automatically keep the web-ext tool up to date to avoid bugs
- Alert the developer if their version of web-ext is out of date
- Offer extension “linting” in code editors
- Integrate web-ext's existing lint checking feature into popular editors such as Atom, Vim, and Emacs
- Add a new web-ext command that lays out a directory structure for an extension
- This command would automatically generate a manifest.json file and other common files to help the developer get started on a new extension
- Build a mock WebExtension API for use in automated tests
- Invent a JavaScript library that developers can use to execute tests for their extension without having to launch a web browser
Contributing to WebExtensions is a great opportunity to empower those who are extending the web!
Desired technical skills:
- Intermediate experience with JavaScript, preferably with some ES6 experience
- Familiarity with the command line environment for NodeJS development
- Ability to communicate in English, primarily in written form
How to familiarize yourself with the project:
- Try out the web-ext tool and file a bug if you find one
- Look through WebExtension examples and try them out with web-ext run
- Search for good first bugs in the web-ext repository and submit a patch
- Search for good first bugs in the sign-addon repository and submit a patch
Build a Library of Inclusion Best Practices and Case Studies
- Mentor: Larissa Shapiro
This project is a community research project to identify and document examples of successful inclusive teams and communities within Mozilla, in order to amplify successes and highlight bright spots. The Outreachy participant will assess programs for suitability, and then interview participants, and then document case studies, referencing appropriate research and industry/community best practices. This is a great opportunity for a person interested in Diversity and Inclusion, Community Building, or User/Community research.
Skills learned in this project will include effective interviewing, case study development, awareness of research in best practices in inclusion across cultures and other diversity dimensions, and wiki markup/editing.
Your work sample should be a short written case study of a program or project you have done as a volunteer or as a new employee, technical or non, and should describe exactly how this program or project included you and failed to include you. Specific examples, connections to research, and detail are appreciated. It should be a several paragraph document.
Improving user experience of Firefox Accounts
- Mentor: Vlad Filippov (vladikoff on IRC)
There are several pending initiatives that are focused on improving the user experience of Firefox Sync and Firefox Accounts. As part of this Outreachy internship project you will be involved in improving user interaction, running experiments, and measuring success of certain features. Your software engineering skills will assist in the following:
Developing new application improvements to reduce the number of user errors on password reset, password change, and sign up flows.
Improving the verification rate and speed of new users signing up for Firefox Accounts.
Skill requirements for this project: Git, JavaScript. Software requirements: Mac OS or Linux. As part of your application please try to fix a ‘good first bug’ at: waffle.io/mozilla/fxa?label=good-first-bug
To get started with Firefox Accounts please visit: github.com/mozilla/fxa-content-server#quick-start
To learn more about Firefox Accounts project check out: fxa.readthedocs.io/en/latest/
Improving server-side components of Firefox Accounts
- Mentor: Vlad Filippov (vladikoff on IRC)
This project is part of improving the server components of Firefox Accounts. You will be involved in improving the security, APIs, and measuring success of certain features. Detailed projects:
Improving Firefox Sync and Firefox Accounts integration. Improving device management and OAuth APIs.
Skill requirements for this project: Git, Node.js. Software requirements: Mac OS or Linux. As part of your application please try to fix a ‘good first bug’ at: waffle.io/mozilla/fxa?label=good-first-bug
To get started with Firefox Accounts please visit: github.com/mozilla/fxa-content-server#quick-start
To learn more about Firefox Accounts project check out: fxa.readthedocs.io/en/latest/
User Impact of XSS Filters within Web Browsers
- Mentors: Christoph Kerschbaumer & Frederik Braun
Cross Site Scripting (XSS) consistently ranks highest in the list of the most prevalent software vulnerabilities. Using XSS, hackers can gain access to confidential user data and conduct transactions on behalf of the user. Many browsers provide a built-in XSS filter to protect the majority of users from XSS issues. Such heuristic based filters also trigger false positives. This may downgrade a user's experience on a benign site. Even worse, such filters might even introduce new vulnerabilities.
To the end of the project we expect you to
- implement an XSS filter within Firefox
- measure user impact based on false positive rate
- measure performance
- co-produce a white paper with the mentors that summarizes the outcome of this project.
- (Pro Tip: This might qualify as a term paper or even grow into a thesis for your studies).
How you can prepare for the program:
- Familiarize yourself with the problem by reading literature on XSS-Filters:
- Introduction of the Chrome/Webkit filter called XSS Auditor in "Regular expressions considered harmful in client-side XSS filters"
- Security vulnerabilities introduced though XSS filters in IE8: https://blog.c22.cc/2010/04/15/blackhat-europe-universal-xss-via-ie8s-xss-filters-2/
- Bypassing XSS filters: (http://www.thespanner.co.uk/2015/02/10/xss-auditor-bypass/, http://brutelogic.com.br/blog/chrome-xss-bypass/)
- Familiarize yourself with the state of the art of implementing an XSS filter
- Browse the source code of NoScript, XSSAuditor in WebKit, or also the source of Internet Explorer (which can be inspected by looking into mshtml.dll)
- Compare approaches of these filters to answer questions like: where do their approaches overlap, which differences exist in their threat models, etc.
- Prepare yourself for implementing a filter within Firefox
- Outline the advantages and disadvantages of existing approaches Sketch out details for the actual implementation
We would be thrilled if you have a
- a deep understanding of Web Security and XSS
- a fundamental understanding of browser architecture
- solid experience in developing C/C++ applications
- the ability to work with a geographically distributed development team
- experience in learning, building and being effective with a large code base
We at Mozilla Security Engineering give you the opportunity to improve Firefox. We are an equal opportunity employer and value diversity. We do not discriminate on the basis of race, religion, color, national origin, gender, sexual orientation, age, marital status, veteran status, or disability status.
taskcluster-cli go implementation
- Mentors: Wander Lairson Costa & Jonas Finnemann Jensen
Background
Mozilla is a company that is strongly committed to inclusion and diversity. The Taskcluster team at Mozilla builds an automation platform, similar in scope to Buildbot and Jenkins. The project is built to support the continuous integration testing of Mozilla projects like Firefox and Rust as well as projects that Mozilla participates in, like NSS. Taskcluster is built using distributed 'cloud' computing services where possible. Taskcluster developers and users often need to do some tasks manually, like craft, inspect and kill tasks; roles and users management; download artifacts, etc. taskcluster-cli is a generic command line tool to interact with Taskcluster, built by and for shell command lovers. We have a long live Javascript implementation, and are starting a new version completely rewritten in Golang.
Project
The goal of this project is to implement the main features to the new Golang based taskcluster-cli, including task creation, task groups scheduling, users management, and so on. We want someone that is keen to learn and engaged on making taskcluster-cli a great tool. You should know basics of Go (Go is a simple language and the basics can be learned during application process). The advanced skills on the language can be acquired during internship with help from project mentors. Some knowledge of Javascript (ES6 is a plus) is desired but not required (although you may expect reading some modern Javascript code from time to time), as well as some general concepts of Web APIs.
Required skills:
- Go programming language (you can learn during application process)
- Desire to learn
- Engagement
Desired skills:
- Javascript
- ES6
- Web APIs
Add support for OpenAPI to Kinto
- Mentors: Ethan Glasser-Camp (glasserc on IRC) and Rémy Hubscher (natim on IRC)
Kinto has a fairly comprehensive set of documentation that describes its API. However, the cool new thing is OpenAPIs (formerly known as Swagger). Documenting our API using this specification would facilitate the implementation of client libraries in other languages as well as open the door to lots of other projects, including "interactive" documentation which has buttons that launch requests against a live server.
The Kinto team is seeking an intern to work on developing OpenAPI support in Kinto. This project is ideal for an Outreachy intern because it is self-contained and doesn't require understanding a complicated ecosystem of services (unlike our previous "Push Notifications" project).
We have structured the project to have multiple tasks. We do not expect any intern to finish every task; instead, we can draw tasks from this reservoir according to your momentum. These tasks are:
- Document the existing API by writing an OpenAPI specification. This will involve reading the existing documentation and experimenting with the Kinto server.
- Add runnable examples to the documentation. This will involve comparative analyses of available tools as well as working with our Sphinx-based documentation.
- Add an automated test that detects when the spec is out-of-date. This would involve working with our py.test-based unit testing suite.
- Write a mechanism to generate an OpenAPI specification from the Kinto source code. This would require writing Python code that hooks into the server code to identify APIs.
- Investigate the use of the OpenAPI specification to do fuzz-testing against the Kinto server. This would require an investigation of fuzzing tools and learning how to use them in a customized way.
Interns should understand back-end REST services and be skilled in reading and writing Python. You should be able to use Git and run Python code.
You can learn more about Kinto at the Kinto Readthedocs page and its Github page. If you need a "small contribution" for your application, some suggestions are at Kinto easy-pick bugs and kinto-http.py easy-pick bugs. You can find us in #kinto on Freenode or on Slack at https://kinto.slack.com/ .
Azure Blob Storage client library
- Mentors: John Ford (jhford on IRC)
Background:
The Taskcluster team at Mozilla builds an automation platform, similar in scope to Buildbot and Jenkins. The project is built to support the continuous integration testing of Mozilla projects like Firefox and Rust as well as projects that Mozilla participates in like NSS. Taskcluster is a built using distributed 'cloud' computing services where possible. We use the Azure Storage framework for storing a lot of things. This library has Queue storage, Table Storage. We have a wrapper that we like a lot called 'azure-entities' in NPM.
Project:
The goal of this project is to write a library to wrap the Azure Blob Storage service. A preliminary effort has already been done. What we're looking for is someone to take this work and extend it to cover the majority of the Blob Storage API. We specifically would like to have the following:
1. All Rest API endpoints implemented using input validation to ensure that only valid data makes it to the API. JSON Schema is a great tool for this 2. Ability to specify a JSON Schema to validate objects that we'll store or append to blobs, and also that we read out from them 3. Ability to use Shared Access Secrets (SAS) as authentication 4. Stretch goal of adding SAS for Blob storage to our authorization service
What you'll learn and use:
- Javascript language
- Node.js environment
- JSON
- Yaml
- JSON-Schema
- Azure Cloud APIs, specifically Blob Storage
- Babel -- Javascript compiler
- ESLint -- Javascript linter
- Javascript Promises and the Async/Await pattern
You should have some experience with Javascript or a similar dynamic language (Ruby, Python, etc). It's not important that you know all of the tools, but you should be willing to learn. You should be available to have meetings at some point in the time window of 9.00h CEST/CET through 17.00h CEST/CET
Improve Template Logic for Taskcluster-Github
Mentor: Brian Stack (bstack on IRC), Dustin Mitchell (dustin on IRC)
Background:
The Taskcluster team at Mozilla builds an automation platform, similar in scope to Buildbot and Jenkins. The project is built to support the continuous integration testing of Mozilla projects like Firefox and Rust as well as projects that Mozilla participates in like NSS. Many of these projects are developed on Github, and the Taskcluster-Github service acts as the interface between the two systems, creating tasks in response to Github events and posting status updates back to Github. As other Mozillians have started using Taskcluster-Github, they have identified some issues and missing features in the service. With those fixed, more Mozillians can use TaskCluster to improve the web.
Project:
This project involves addressing some of the more pressing user-identified issues with TaskCluster. It is a collection of smaller projects:
1. Add support for creating tasks in response to new Git tags. This would allow users to run "release" tasks when they push a new version tag, for example.
2. Make the repository enrollment process "self-serve". Currently, if a team wants to use Taskcluster-Github, they must ask a person on the Taskcluster team to set that up for them. That can be slow and discourages experimentation. With this project completed, users can set up a new repository with a few clicks.
3. Add "build shields", similar to http://shields.io/ that will show the latest status of a Taskcluster-Github build or test run.
As a collection of smaller projects, there is plenty of flexibility to add or remove projects during the internship. You are encouraged to talk to other teams in Mozilla and, if you find a feature that will help them use Taskcluster more effectively, implement that feature instead.
What you'll learn and use:
- Javascript (mostly server-side, using node)
- Github Webhooks and APIs
- Taskcluster APIs
Previous Experience:
You should be familiar with Javascript, although it is OK if that is limited to scripts that run in the browser. You should be familiar with Github, including making pull requests and using continuous integration tools like Travis-CI or CircleCI. Ideally, you would have some experience working with other people on an open-source project, modifying existing code and getting feedback in reviews.
Collaboration Tools for Open Source Participation and Productivity
Mentor: Don Marti
We are interested in pushing the limits of what automation can do to help de-stress open source projects, especially low-profile ones that put a lot of work onto an individual maintainer or small team. Interested in writing bots to help maintainers with the routine tasks of software development, bots that can help coach new contributors to get productive, or both? If you have an idea for a collaborative tool that would help you, and you're interested in coding it and seeing if it can help others, please consider joining us. Helpful skills to have
- HTTP client development
- Use of web APIs (GitHub, Twitter...)
- git
- Empathy for new and time-crunched developers
None of these are hard requirements -- We're prepared to collaborate with you and your bot(s) to learn and gather data.
Help drive the Nightly Reboot on Firefox Desktop/Mobile
Mentor: Marcia Knous (marcia on IRC)
This project involves helping the Release Management team and the Mozilla community drive the "Nightly Reboot" on Firefox Desktop and Mobile. You can read more about it here: https://blog.nightly.mozilla.org/2016/07/01/a-firefox-nightly-blog/. Here are some of the things you will work on as part of this internship:
Bug and Crash triage
- Help the team identify and triage Nightly bugs
- Identify and investigate crashes in the Nightly project
- Organize Test Days specific to Firefox Nightly
Applicants should have:
- Experience using the Firefox browser and an understanding of what the Firefox Nightly Channel is
- Strong organizational abilities
- Inquisitive nature
- Comfortable working in Bugzilla
- Bonus if you have experience doing QA
Applicants will gain skills in:
- Investigative analysis
- Problem solving
This should be a fun experience, especially for those who love working on solving problems and making the Firefox experience better for everyone!
Outreachy Program Cohort: Round 12 (May-August 2016)
Enhancements to Python testing tool plugin for generation of HTML reports
- Mentor: Dave Hunt
- Participant: Ana Ribero
- Participant Blog
Inclusive culture is essential to building all kinds of diversity and making diverse people feel welcome in open source projects. We have many groups working on this topic all around Mozilla and other open source communities. This Outreachy participant will engage in community research, documenting best practices and case studies in the development of open inclusive culture.
The participant will be responsible for developing enhancements to pytest-html - a plugin based on the popular Python testing tool pytest, which generates a HTML report based on test results.
The desired enhancements include: gracefully degrading when JavaScript is not available; saving CSS, images, and other resources as additional files rather than embedding in a single file; grouping results by package/module/class; and including test docstrings in the report.
Any new enhancements to the plugin must also be accompanied with tests, which will ensure that these new features work in all expected environments, and reduce the chances of regression.
Make Firefox look great on desktop!
- Mentor: Gijs Kruitbosch
- Participant: Rakhi Sharma
- Participant Blog
Firefox for desktop is used by hundreds of millions of people every day. We control what it looks like using CSS, XUL (a markup language that's a bit like HTML), and JavaScript. There's also a small amount of C++ here and there.
For this project, the participant will help to address a number of styling problems where Firefox does not currently look its best.
Project SmartHome prototyping
- Mentors: Kate Glazko and Marcia Knous
- Participant: Manel Rahem
- Participant Blog: https://mermi.github.io
The participant will be involved with Project SmartHome, working on assisting active and ongoing prototyping, integrating logging and metrics into SmartHome work with the collaboration of the metrics team, and helping with user research testing analysis and results.
Webcompat.com Web Application Engineer
- Mentor: Mike Taylor
- Participant: Deepthi Venkitaramanan
- Participant Blog
Mozilla's Web Compatibility team builds and maintains a web application called webcompat.com that allows individuals to easily report site compatibility issues - and to allow us to better understand the larger picture of compatibility issues affecting Firefox users on the web.
In this Outreachy project, the participant will contribute to one or more of the following projects to help us succeed from a few different angles.
- Design and implement a system that allows site owners and developers to register for notifications (i.e., RSS, E-mail) for issues related to a given domain
- Design and build a user interface that allows bug reporters to identify possible duplicate problems
- Use cutting edge features like Service Workers to enable offline and sync capabilities between the client and server
- Migrate webcompat.com front-end to use ES6 modules (likely powered by something like Babel)
Convert Mozmill tests to Marionette
- Mentor: John Dorlus <jdorlus@mozilla.com>, Silne30 on IRC
- Participant: Benjamin "Benny" Forehand, Jr.
- Participant Blog: https://www.bennyjr.xyz/blog and https://benjaminfjr.blogspot.com/
This project involves reading and writing code in both Python and Javascript. Mozmill is one of Mozilla’s older automated testing frameworks; tests written in Mozmill are being ported to Marionette, which is an implementation of the Webdriver standard, capable of interacting with both web content and browser UI. Applicants should have a strong knowledge of Python and at least some exposure to Javascript. The starting point (and main focus) for this project will be the work outlined in Bug 1132680; there is other work in the same area that can be done if that bug gets finished early.
Realtime Push Notifications for Kinto
- Mentor: Remy Hubscher
- Participant: Ipsha Bhidonia
- Participant Blog
Kinto is the Mozilla storage solution to backup and sync Firefox Account Users data. It is currently used as a backend for Firefox OS applications and for Firefox and Fennec updates in the Go Faster projects. https://kinto.readthedocs.org
Today a notification system allow us to notify Firefox and Fennec users for them to come and get updates.
The participant would extend the notification system to implement realtime updates between devices.
- On the server side we are using Pyramid and Python with a bit of AsyncIO
- On the client side this will involve JavaScript and Websocket management.
Test-driven Refactoring of Marionette's Python Test Runner
- Mentor: Maja Frydrychowicz
- Participant: Anjana Vakil
Marionette's Python Test Runner is slated to become the canonical harness for running most new automated tests for Firefox, but it needs to be lovingly cleaned up and stabilized first. We've already started this work and we're excited to have you help us continue.
We want it to be easy and safe for teams around Mozilla to customize the Test Runner for their needs, so we're writing a suite of tests for the Test Runner itself to prevent breaking any existing automation infrastructure -- i.e. we're testing the thing that runs Firefox tests. Part of your role will be to write more of these tests. While writing tests, you will naturally find areas in the Test Runner code that need to be improved or reorganized in order to be testable in the first place. This is what we mean by "test-driven refactoring". Other tasks might include:
- Making the test results more informative and easy to read on Treeherder's log viewer.
- Making the tests more convenient to run locally with mach.
Add robust AMI management to the TaskCluster AWS Provisioner
- Mentor: Dustin J. Mitchell
TaskCluster (https://tools.taskcluster.net) is a distributed task execution system Mozilla uses to build, test, and release Firefox. The AWS provisioner is the component responsible for managing the AWS EC2 instances that execute tasks. The project is to improve its management of AMIs, making them easier to create, deploy, and clean up.
Improving user experience of Firefox Accounts
- Mentor: Vlad Filippov (vladikoff on IRC)
There are several pending initiatives that are focused on improving the user experience of Firefox Sync and Firefox Accounts. As part of this Outreachy internship project you will be involved in improving user interaction, running experiments, and measuring success of certain features. Your engineering skills will assist in the following:
- Developing new application improvements to reduce the number of user errors on password reset, password change, and sign up flows. This will give you developer experience working with the Firefox Accounts UX team.
- Experimenting with “Show Password” UX. Determining which design is more effective in terms of speed and popularity.
- Improving the verification rate and speed of new users signing up for Firefox Accounts.
Content Process Management Tool
- Mentor: Mike Conley
- Participant: Rutuja Surve
- Participant Blog
"With multi-process Firefox going out the door in the very near future, we're looking at scaling up and tuning the number of content processes that Firefox starts and uses.
Memory usage is something we want to keep an eye on while we do this, so this project is about building a Content Process Management tool that can track real-time memory usage across each process. We might increase the number of uses of the management tool over time, but we'll start with memory management.
Taskcluster tools UI/UX improvements
- Mentor: Wander Lairson Costa
- Co-Mentor: Dustin J. Mitchell
- Participant: Andrea Del Rio Lazo
Taskcluster is the new Mozilla CI that will in future be responsible to run every build and test for Firefox, Firefox TV, rust and other Mozilla projects. We are a small and passionate team engaged to make Taskcluster the best CI ever.
Automation of Taskcluster Documentation
- Mentor: Jonas Finnemann Jensen and Brian Stack
- Participant: Kristel Teng
Our task execution platform TaskCluster consists of many small services. We would like a system to which each component can upload its documentation in a reference format markdown for text, JSON for API references, etc. From the uploaded references we would then generate the entire documentation site.
By uploading documentation and reference files from the services, we can have it automatically update when we deploy new features. Services already uploads some formal JSON references, but this needs more structure.
Technically speaking:
- A node.js module for uploading a directory of JSON files + a manifest - A service generating a static documentation site from uploaded documentation.
Useful skills:
- node.js - HTML/CSS/JS (react.js would be nice to have) - Some graphical design skills
This is not a project about writing documentation, most of it already exists. It needs automatic deployment and structure.
Fixing some papercuts in the Firefox desktop user interface
- Mentor: Jared Wein
- Participant: Katie Broida
- Participant Blog
Firefox for desktop is used by hundreds of millions of people every day. We control how it works and what it looks like using CSS, XUL (a markup language that's a bit like HTML), and JavaScript. There's also a small amount of C++ here and there.
Some of the work will cover:
- Improving entering and exiting of Reader Mode
- Cleaning up the styling of our getting-started tour
- Improving shadows of the dropdowns for the URL and search box
- Increasing legibility of the menubar on Windows 8
- Researching and improving the Windows 10 Start Menu tile for Firefox
- Showing the Windows 10 accent color in the Firefox title bar
Web Platform Test Crime Scene Investigation
- Mentor: Ehsan Akhgari
- Participant: Decky Coss
- Participant Blogs: http://cosstropolis.com/blog and http://cosstropolis.com/blog/feed.xml
"We run a lot of automated tests against each revision to Firefox’s code, and we verify that code changes do not cause tests to stop passing. One group of tests, called Web Platform Tests, is shared among all major web browsers, and we have only begun running them recently. As a result, we imported thousands of tests and marked some of them as currently failing, and they have languished in that state. Some of these failures are caused by Firefox not correctly implementing an edge case, while others may be very important problems - as things stand, it's hard to figure out which ones are which. We need your help cleaning up this mess!
Prototype new Firefox features with the Test Pilot team
- Mentors: Jared Hirsch (_6a68 on IRC) and Dave Justice (JSON_voorhees on IRC)
- Participant: Jen Kagan
- Participant blog
The Mozilla Test Pilot team is seeking someone to join a small, enthusiastic team focused around rapidly testing new features in Firefox. The team's process is built around getting feedback frequently and directly from an active user base which allows rapid iteration of the feature design.
In this program, you will participate in a well-documented four step process:
- Lo-Fi Validation: Sketches, ideation, paper prototypes, and user research.
- Prelaunch: Define and build a minimum viable product, establish your testing protocols, and validate the research.
- Active Testing: Launch and test your prototype, collect metrics and feedback, evolve and re-test.
- Sunsetting: Analyze the tests and determine release platforms.
As this program is about rapidly evaluating potential new features, the specifics of what the participant will be developing this summer haven't been settled yet--but ideas are floating around security, privacy, tracking protection, and file transfer. Below are some examples of what the team is currently prototyping as of February 2016:
- Universal Search: adding recommendations from sources around the internet directly into the Awesome Bar.
- Tab Center: rethinking tab management by moving tabs to the side of the browser and making them easier to search.
- Better 404s: Using the Internet Archive's Wayback Machine to replace 404 pages with an older version of the page.
- Page Shot: Enabling smarter sharing of screenshots by copying DOM content as well.
For Future Applicants
- Next Outreachy round is Winter 2016-17. Keep in touch by reading here or on gnome.org/outreachy to learn application deadlines.
Application Process
Applicants and mentors, please review the Outreachy Eligibility and Application Information page to learn more about applying for Outreachy.
First steps for applicants to Mozilla:
- Set up IRC.
- Set up a Bugzilla account and a Mozillians profile. Please include your IRC nickname in both of these accounts so mentors can work with you more easily. For example, Eve Smith would set their Bugzilla name to "Eve Smith (:esmith)", where esmith is their IRC nick.
- Please look at the projects below, consider your options, and chat with Mozilla mentors on IRC. You need to make a small contribution to the area you wish to apply for.
- To chat with Mozilla mentors, join the #outreachy channel on irc.mozilla.org.
- To ask general questions about Outreachy or the application process, you can also try #outreachy IRC channel on irc.gnome.org.
Projects to Apply for
There will be several Mozilla Outreachy projects for Round 13. Got Questions? Ask:
Outreachy Coordinator:
- Larissa Shapiro, Sr Program Manager, Diversity and Inclusion
IRC: #outreachy
Past Outreachy/OPW internships
Complete List of Participants
ROUND 11
Lauren Conrad
Participant: Lauren Conrad
Based in: Rye Brook, New York USA. (For anyone who doesn't know, that's a suburb right outside New York City!)
Mentor: Joni Savage
"I am thrilled to be working for such a well known company and to be translating my writing skills into the tech world."
Project: SUMO - Build a tutorial or training tool for new technical writers
Project blog: www.laureneconrad.com
Roxana Ilie
Participant: Roxana Ilie
Based in: Bucharest, Romania
Mentor: Patrick McManus
"I am very excited to be joining the Mozilla Outreach Program because after enjoying so much using the browser, I will have the opportunity to give something back and use my knowledge in order to help the community to improve Mozilla Firefox."
Project: Battery Friendly Platform Networking Deadline Scheduler
Richa Rupela
Participant: Richa Rupela
Based in: Bikaner, Rajasthan, India
Mentor: Anne van Kesteren
"Super excited to work on Whatwg project, mentored by Anne van Kesteren. Mozilla Outreach program has given me a great opportunity of working with a such a elite community. Looking forward to an awesome winter where I will work on the HTML standards!"
Richa's project blog: https://richarupela.wordpress.com/
Project: Contribute to the HTML Standard!
Shweta Oak
Based in: Mumbai, India
Mentor: Alexis Metaireau
"I am extremely excited to be a part of an organization that is so instrumental in the development of the open web and get a chance to make contributions that enrich the lives of people."
Project: Kinto — Make instances discoverable
Jullie Utsch
Participant: Jullie Utsch
Based in: Belo Horizonte - MG Brazil
Mentor: Ilana Segall
“What makes me excited about Outreachy: Being part of a great community, sharing with incredible people and taking part in making the tech industry a little more diverse. :)”
Project: Visual Design with Research Data
Cynthia Anyango
Participant: Cynthia Anyango Based in: Nairobi , Kenya
Mentor: Karl Thiessen
"I am excited to join Mozilla for the outreach program especially the project I am attached to because I get to contribute to open source Mozilla services that make lives better"
Project: Enumerate (and Dockerize) the tests! (Quality Assurance)
Nikki Bee
Participant: Nikki Bee
Based in: Alberta, Canada
Mentor: Josh Matthews
"I'm excited at the chance to learn Rust and contribute to a major FOSS project, especially for an organization that has been as welcoming as Mozilla."
Project: Servo: Complete implementation of Fetch standard
My Lê
Based in: Paris - France
Mentor: Ricardo Vazquez
"Proud to be part of Mozilla Outreachy Program, sharing knowledge and contributing to the Open Web."
Project: Open Source Designer, Mozilla Foundation
ROUND 10
https://wiki.gnome.org/Outreachy/2015/MayAugust#Participating_Organizations
Thalia Chan (Tchanders), London, UK - Socorro crash statistics front-end development - Adrian Gaudebert
Alice Duarte Scarpa (adusca), Rio de Janeiro, Brazil - Integrate the ability to arbitrarily retrigger jobs into functional tools & production quality code - Armen Zambrano Gasparnian
Gloria Dwomoh (blossomica), Piraeus, Greece - Air Mozilla web design and development - Peter Bengtsson
ROUND 9
https://wiki.gnome.org/OutreachProgramForWomen/2014/DecemberMarch#Participating_Organizations
Lisa Hewus Fresh Portland, OR, USA - Air Mozilla Web Design and Development - Peter Bengtsson
Tessy Joseph (tessy), Kerala, India - One and Done - Rebecca Billings
Barbara Miller (galgeek), Portland, OR, USA - QA/Automation - Henrik Skupin
Adam Okoye (aokoye), Portland, OR, USA - SUMO/Input Web Design and Development - Will Kahn-Greene
ROUND 8
https://wiki.gnome.org/OutreachProgramForWomen/2014/MayAugust#Participating_Organizations
Francesca Ciceri (MadameZou), Massa, Italy - Bug wrangling - Liz Henry
Joelle Fleurantin (Queeniebee), New York, NY, USA - Maintaining the Gateway: Improving Mozilla Wiki through updating Information Architecture and Theme - Christie Koehler
Maja Frydrychowicz (maja_zf), Montreal, Quebec, Canada - Django development for One and Done - Liz Henry
Sara Mansouri (sara_mansouri), Saskatoon, Saskatchewan, Canada - Redevelopment of badges.mozilla.org and other contributor gamification infrastructure - Larissa Shapiro
ROUND 7
https://wiki.gnome.org/OutreachProgramForWomen/2013/DecemberMarch#Participating_Organizations
Isabelle Carter (ibnc), Springfield, MO, USA - Servo - Lars Bergstrom
Jennie Rose Halperin (jennierose), Carrboro, NC, USA - Community building - Larissa Shapiro
Jennifer "Nif" Ward (nif), Oberlin, OH, USA - Rust - Tim Chevalier
Sabina Brown (binab), Santa Cruz, CA, USA - SUMO (Support.Mozilla.org) community building - Ibai Garcia
ROUND 6
https://wiki.gnome.org/OutreachProgramForWomen/2013/JuneSeptember#Participating_Organizations
coordinators: Selena Deckelmann and Liz Henry
Gabriela Salvador Thumé (gabithume), São Carlos, São Paulo, Brazil - Socorro - Selena Deckelmann
Tiziana Sellitto (tiziana), Salerno, Italy - Bug wrangling - Liz Henry
ROUND 5
https://wiki.gnome.org/OutreachProgramForWomen/2013/JanuaryApril#Participating_Organizations
Lianne Lee (llmelon), Sydney, Australia - Release metrics dashboard - Lukas Blakk