Difference between revisions of "Potential Projects"

From CDOT Wiki
Jump to: navigation, search
m (Reverted edits by Saoagent (Talk) to last revision by Chris Tyler)
 
(48 intermediate revisions by 28 users not shown)
Line 5: Line 5:
 
'''Students:''' If you'd like to work on one of these, move the chosen project to the [[Project List]] and create a page for your work based on the [[Sample Project]] template.
 
'''Students:''' If you'd like to work on one of these, move the chosen project to the [[Project List]] and create a page for your work based on the [[Sample Project]] template.
  
<span style="background: #ffff00">'''Note:'''</span> OSD/DPS students are encouraged to select a Mozilla or OOo project. LUX students are encouraged to select a Fedora project. If you are interested in a project from the other community, please discuss it with your professor.
+
'''Open Source Community Members:''' We welcome your recommendations for potential projects. Please create an account on this Wiki and create a description for your proposed project below. Please list your contact info (just an IRC or FAS2 name is OK) as well as links to any related web pages as Resources for the proposed project. (Questions? Ask [[user:Chris Tyler | Chris Tyler]] or [[user:David.humphrey | David Humphrey]]).
 +
 
 +
= SBR600 Potential Projects =
 +
 
 +
For possible projects for the SBR600 Software Build and Release Course, lease see the [[SBR600 Potential Projects]] page.
 +
 
 +
= Potential Eclipse WTP Projects =
  
'''Open Source Community Members:''' We welcome your recommendations for potential projects. Please create an account on this Wiki and create a description for your proposed project below. Please list your contact info (just an IRC or FAS2 name is OK) as well as links to any related web pages as Resources for the proposed project. (Questions? Ask [[user:Chris Tyler | Chris Tyler]] or [[user:David.humphrey | David Humphrey]]).
+
See the list of potential bugs [https://bugs.eclipse.org/bugs/report.cgi?x_axis_field=priority&y_axis_field=product&z_axis_field=bug_severity&query_format=report-table&short_desc_type=allwordssubstr&short_desc=&classification=WebTools&product=WTP+Common+Tools&product=WTP+ServerTools&product=WTP+Source+Editing&product=WTP+Webservices&long_desc_type=allwordssubstr&long_desc=&bug_file_loc_type=allwordssubstr&bug_file_loc=&status_whiteboard_type=allwordssubstr&status_whiteboard=&keywords_type=allwords&keywords=&bug_status=NEW&bug_status=REOPENED&bug_severity=major&bug_severity=normal&bug_severity=minor&bug_severity=trivial&priority=P2&priority=P3&priority=P4&priority=P5&emailtype1=substring&email1=&emailtype2=substring&email2=&bugidtype=include&bug_id=&votes=&chfieldfrom=&chfieldto=Now&chfieldvalue=&format=table&action=wrap&field0-0-0=assigned_to&type0-0-0=regexp&value0-0-0=.@ca.ibm.com&field0-0-1=noop&type0-0-1=noop&value0-0-1= here].
 +
 
 +
<!--
  
 
= Potential Fedora Projects =
 
= Potential Fedora Projects =
Line 21: Line 29:
 
Lots of good ideas are listed in [[:fedora:SummerCoding/2008/Ideas|Summer Coding Ideas (Fedora Wiki)]]. These projects were originally proposed for Google Summer of Code projects; if you want to use one of them, please discuss it with [[User:Chris Tyler|Chris Tyler]] before selecting it, because the scope and mentorship model for GSOC is different from that of the LUX projects.
 
Lots of good ideas are listed in [[:fedora:SummerCoding/2008/Ideas|Summer Coding Ideas (Fedora Wiki)]]. These projects were originally proposed for Google Summer of Code projects; if you want to use one of them, please discuss it with [[User:Chris Tyler|Chris Tyler]] before selecting it, because the scope and mentorship model for GSOC is different from that of the LUX projects.
  
== Free-open font packaging ==
+
== Cobbler Web ==
 
 
The gratis release of a collection of web fonts in 1996 had a devastating effect on many font projects, drainning the font market in western countries and limiting the use of other typefaces to typography niches. However, this program has been discontinued and the gratis versions of those fonts are no longer updated. Since Unicode.org's codification pace of human scripts has not abated, and the font formats have evolved (with the OpenType specifications), this font set is increasingly obsolete. Also, many scripts were never covered, leaving entire world regions without mass access to a way to write their language in the digital age.
 
 
 
An operating system of browser that relies on the 1996 font set for its text rendering is not really free. And text is still our main information media.
 
 
 
Faced with this problem many individuals and organisations have started creating and publishing new fonts, but they lack the clout of multinationals to get successfully distributed, and are often poorly structured. The aim of this project would be to identify as many of those free fonts as possible and package them in Fedora. The result would serve as a core component of Fedora's art spin, and as basis for a richer international experience in Fedora (and derivatives such as OLPC)
 
 
 
This project is mainly targeted at free software (in this case fonts) distribution dynamics. You'll learn some rpm packaging skills, and be exposed to many different font projects worldwide, some big, some small, some efficient, some poorly run.
 
 
 
A project second stage would be to capitalize on the experience acquired and publish a set of distribution best practices for font authors, including recommended release composition, generic makefile, etc.
 
 
 
The Fedora [http://fedoraproject.org/wiki/Categories:Fonts_SIG Fonts special interest group] will provide mentoring, technical support, and [http://fedoraproject.org/wiki/Category:Fonts_packaging documentation]. An initial [http://fedoraproject.org/wiki/Category:Font_wishlist list of fonts to package] has already been published.
 
  
Contact: Nicolas Mailhot <nim AT fedoraproject.org>
+
Cobbler is a Linux install server that simplifies tasks associated with fully automated installation such as DHCP, DNS, kickstart, yum, and virtualization.  It aims to be a universal install server for all linux distributions.  Currently Cobbler has a web interface that allows users an easier way of interacting with cobbler.  There are several core improvements that can be made.  One idea is to extend cobbler web to produce views that make it easier for users to edit fields that only they edit (let me reinstall systems I own but don't show me fields I shouldn't care about).  Another is to enable search features in the web app to make it tolerate thousands of systems to a better extent.  Finally, another feature is to add a task engine to cobblerd, to make it possible to run commands like "cobbler import" and "cobbler reposync" in the background and see their output in the web interface via an AJAXy type system.
  
== Corresponding Source Web App ==
+
Possible features are not limited to the above (or just working on the web interface), Cobbler has an ongoing RFE list in Trac that has a wide variety of potential ideas, and ideas beyond the ones listed are also fair game.  See https://fedorahosted.org/cobbler/report/1?sort=type&asc=1
  
Finish design and implement web application that provides downloadable SRPMS for any package+tag in the Fedora Package Source Code Control system. While we provide SRPMS for all packages at release, the updates and rawhide trees churn their packages more rapidly, and will remove the koji-built SRPMS when the binary packages are removed. This would allow people to request source corresponding to the packages they have on ISO media or otherwise.
+
Resources: http://fedoraproject.org/cobbler
  
Resources: MattDomsch, http://git.fedorahosted.org/git/?p=correspondingsource.git;a=blob;f=DESIGN;hb=HEAD
+
Contact: Michael DeHaan
  
 
== Personal Koji Repositories ==
 
== Personal Koji Repositories ==
Line 60: Line 56:
  
 
  * https://fedorahosted.org/bodhi/ticket/160
 
  * https://fedorahosted.org/bodhi/ticket/160
 
== Packaging JBoss ==
 
 
JBoss is a Java middleware project with a large number of sub projects. Packaging JBoss and maintaining them is a challenging task and would require several weeks of full time work. Since OpenJDK and a number of Java components is already in Fedora 9, it should help get started.
 
 
Initial Contact: Greg Dek <gdk AT redhat.com>
 
 
References:
 
* http://fedoraproject.org/wiki/Packaging/Java
 
* http://jpackage.org
 
  
 
== Benchmark Nightlife Scalability Issues ==
 
== Benchmark Nightlife Scalability Issues ==
  
 
Using Puppet, or some other management tool, create a grid of a  
 
Using Puppet, or some other management tool, create a grid of a  
dozen machines, then turn that into 12,000 machine. Address the network  
+
dozen machines, then turn that into 12,000 machines. Address the network  
 
characteristics - how much bandwidth do you need on different  
 
characteristics - how much bandwidth do you need on different  
 
components, the communication mechanisms - does UDP work at such a  
 
components, the communication mechanisms - does UDP work at such a  
 
scale, the grid topology - what happens when two nodes are behind firewalls.
 
scale, the grid topology - what happens when two nodes are behind firewalls.
 
Resource: [[:fedora:Nightlife|Nightlife wiki page]], Matthew Farrellee
 
 
== Add IPv6 Support to Condor ==
 
 
Sooner or later we're going to have to live with IPv6. Many
 
applications are very tied to IPv4 and that includes Condor. Understand
 
what IP addresses really mean to Condor, like many existing systems, and
 
what the implications of an IPv6 conversion means and how it can be
 
done. There are many resources about IPv6 interfaces, but not many good
 
transition guides, and fewer that address what the change can really
 
mean to an application - Condor takes addresses and passes them as ascii
 
text between components.
 
 
Resource: [[:fedora:Nightlife|Nightlife wiki page]], Matthew Farrellee
 
 
== Update Condor Build System ==
 
 
At the foundation of many good applications is its build
 
infrastructure. The latest generation of tools includes GNU make with a
 
very powerful interpreted language and ever increasing functionality in
 
autotools. Condor has a build system from a few generations back. It
 
uses imake, originally designed for building X. While new systems are
 
more powerful and provide enhanced functionality, there isn't always a
 
clear mapping to features of older systems. Don't only find a way to use
 
newer tools to build Condor, but find a way to use the power of current
 
generation tools in ways that aren't just a straight mapping of need
 
satisfied by older systems.
 
  
 
Resource: [[:fedora:Nightlife|Nightlife wiki page]], Matthew Farrellee
 
Resource: [[:fedora:Nightlife|Nightlife wiki page]], Matthew Farrellee
Line 127: Line 85:
 
Resource: [[:fedora:Nightlife|Nightlife wiki page]], Matthew Farrellee
 
Resource: [[:fedora:Nightlife|Nightlife wiki page]], Matthew Farrellee
  
<!-- Commented out by Chris Tyler 2008-08-31 -- I think we'll get all the students doing this.
+
--- Below: Commented out by Chris Tyler 2008-08-31 -- I think we'll get all the students doing this.
  
 
== Review Packages ==
 
== Review Packages ==
Line 142: Line 100:
 
-->
 
-->
  
= Potential Fedora+Mozilla Projects =
+
= Potential Mozilla Projects =
  
 
== [[Sample Project]] ==
 
== [[Sample Project]] ==
Line 150: Line 108:
 
NOTE: if someone has already created the project page, speak to this person and see if you can join them.  If so, simply add your name to the '''Project Leader(s)''' page.  Otherwise, you can become a contributor later.
 
NOTE: if someone has already created the project page, speak to this person and see if you can join them.  If so, simply add your name to the '''Project Leader(s)''' page.  Otherwise, you can become a contributor later.
  
== NetworkManager Web Authentication ==
+
== Improve Localization build system ==
  
[http://www.gnome.org/projects/NetworkManager/ NetworkManager] knows how to connect to many different types of networks, both wired and wireless, and can auto-authenticate to WEP and WPA networks. However, it can't auto-authenticate to networks that require a web-based login, which includes many wired and wireless networks such as [http://www.senecac.on.ca/senenet/ SeneNET] and [http://www.yorku.ca/computng/students/internet/airyork/index.html AirYork].
+
Currently it requires many many steps to produce another language of Firefox.
 +
It would really easy to package these many steps to reduce the required knowledge to generate a new language.
  
Modify NetworkManager so that it talks (though dbus) to a Firefox extension for automatic login to a web-authenticated network.
+
Adding a few make steps to wrap this process would help everyone.
 +
This is a very easy project to tackle but very benefitial if the time and love is given to it.
  
Resources: ctyler, (roc, callion for dbus)
+
Reference: armenzg
  
== Create a MDRK Spin ==
+
== Create a cross-repo pushlog to see all locales's checkins ==
 +
We currently check many different repositories to trigger builds when a developer makes a change. We also check the localizer's repositories to see if they have pushed any changes. The problem is that we have close to eighty different localization repositories and that takes a long time to check each one of them.
 +
If we had a joint view that would improve our systems. An example of that view is:
 +
https://l10n-stage-sj.mozilla.org/pushes/
 +
but the format should be more like this:
 +
http://hg.mozilla.org/mozilla-central/pushlog
 +
which is what our release engineering systems check for.
 +
This project would require you to hack hg and pushlog to make it work.
 +
armenzg has many blog posts explaining how to setup pushlog in your local machine.
  
The [[Mozilla Developer Resource Kit]] is a set of tools, code, and documentation intended to make it easy for new Mozilla developers to get up to speed. Package the MDRK components (including the software tools, a Moz source tree, and documentation) as RPM packages and then create a Fedora "spin" (Live + Installable DVD) of these packages.
+
Reference: armenzg - Bug 498641
 
 
Edit the spin image (from Revisor/Live CD Tools) so that, in addition to being a bootable/installable disc, the image can be run in a VM under Windows/Mac OSX. The disc image must be edited to include Windows/Mac OSX versions of the tools, so that if the disc is inserted into a running Windows or Mac OSX system, the appropriate version can be installed.
 
 
 
Resources: humph, ctyler, http://142.204.133.123/mxr, http://zenit.senecac.on.ca/wiki/dxr
 
 
 
= Potential Mozilla Projects =
 
 
 
== [[Sample Project]] ==
 
 
 
This is a sample project stub.  You can use the template for [[Sample Project]] in order to create a project page for one of the stubs below.  This is how you 'sign-up' for a project.
 
 
 
NOTE: if someone has already created the project page, speak to this person and see if you can join them.  If so, simply add your name to the '''Project Leader(s)''' page.  Otherwise, you can become a contributor later.
 
 
 
== Add Offline Support to an open source web app ==
 
 
 
Firefox 3 supports offline abilities, such that web developers can write their apps so they work even when no network is present.  Good headway has been made already [http://www.bluishcoder.co.nz/2007/02/offline-zimbra-with-firefox.html porting Zimbra].  Pick another web app and add offline support, for example: [http://moodle.org Moodle].
 
 
 
References: mfinkle
 
  
 
== Thunderbird SMTP Auto-Sensing ==
 
== Thunderbird SMTP Auto-Sensing ==
Line 186: Line 136:
 
References: #maildev
 
References: #maildev
  
== Firebug "linting" for portability problems ==
 
  
Lots of web developers use Firebug and Firefox for building their applications, but we want those apps to work well in other browsers as well.  If Firebug knew about JS or CSS patterns that could cause problems in other browsers, it would make it much easier to have those applications work in all browsers.
 
  
Resources: mfinkle, robcee
+
== <strike>XULRunner Application Packaging ==
 
 
== XULRunner Application Packaging ==
 
  
 
Help to develop an [http://www.mozpad.org/doku.php?id=application_build_system_project automated packaging system] for XULRunner applications.
 
Help to develop an [http://www.mozpad.org/doku.php?id=application_build_system_project automated packaging system] for XULRunner applications.
  
Resources: plasticmillion, mfinkle, #mozpad, #prism
+
Resources: plasticmillion, mfinkle, #mozpad, #prism</strike>
  
 
== 'Compact databases' feature for Mozilla calendaring applications (Lightning, Sunbird) ==
 
== 'Compact databases' feature for Mozilla calendaring applications (Lightning, Sunbird) ==
Line 206: Line 152:
 
Resources: ctalbert, daniel in #calendar on irc.mozilla.org
 
Resources: ctalbert, daniel in #calendar on irc.mozilla.org
  
== Thunderbird Draft Scheduler Extension ==
+
== <strike>[[Spellcheck Extension for Arbitrary Web Pages]]</strike> ==
 
 
Write an extension for Thunderbird so that the user has the ability to mark a draft email for sending later.  This is not the same as having to save emails in your DRAFT box because users would have to remember to go back in and click Send later.  What is different here is that users could set the date and time for each email to be sent.  This feature would be helpful to those who work late into the night but prefer not to send emails at such a late hour.  This feature would also benefit support staff, e.g., administrative assistants, who constantly have to send out regular email reminders, e.g., for meetings, timesheets, etc.
 
 
 
Resources: Vivian Ngo
 
 
 
== [[Spellcheck Extension for Arbitrary Web Pages]] ==
 
  
Write an extension to leverage the existing spellcheck code in Mozilla and add the ability to highlight spelling mistakes for a given web page (i.e., vs. a textbox).
+
<strike>Write an extension to leverage the existing spellcheck code in Mozilla and add the ability to highlight spelling mistakes for a given web page (i.e., vs. a textbox).</strike>
  
== Modify Firefox to handle files downloaded to Temp more appropriately ==
+
== <strike>Modify Firefox to handle files downloaded to Temp more appropriately </strike>==
  
Often files downloaded by the browser are put in a temporary folder that is emptied on close.  Users (and especially novice users) should be protected from inadvertent data loss as a result of important files being saved to this temp folder.  This project will add fixes to the browser so that users are protected.  Ideas include:
+
<strike>Often files downloaded by the browser are put in a temporary folder that is emptied on close.  Users (and especially novice users) should be protected from inadvertent data loss as a result of important files being saved to this temp folder.  This project will add fixes to the browser so that users are protected.  Ideas include:
  
 
* Make Firefox aware of common productivity file types (e.g., .doc, .pdf) and whitelist these types so they aren't deleted
 
* Make Firefox aware of common productivity file types (e.g., .doc, .pdf) and whitelist these types so they aren't deleted
Line 227: Line 167:
 
* Have the browser pop-up a Save As dialog instead of automatically saving to temp, and use a documents path
 
* Have the browser pop-up a Save As dialog instead of automatically saving to temp, and use a documents path
  
Other ideas are possible, and a combination of these might be necessary.  Ultimately, this fix should target regular users without much knowledge of the filesystem.
+
Other ideas are possible, and a combination of these might be necessary.  Ultimately, this fix should target regular users without much knowledge of the filesystem.</strike>
  
 
Resources: ted, mfinkle
 
Resources: ted, mfinkle
Line 247: Line 187:
  
 
References: Ben Hearsum (bhearsum), Rob Helmer (rhelmer)
 
References: Ben Hearsum (bhearsum), Rob Helmer (rhelmer)
 
== Thunderbird Image Auto-Resize ==
 
 
Write an extension for Thunderbird that gives functionality similar to that of Outlook, where image attachments in an email can be automatically re-sized to one of a set of smaller sizes.  This is helpful for users who would otherwise try to send megabytes of image data, when they can safely scale the images down and still share their pictures with friends.
 
 
References: #maildev
 
  
 
== Port the Firefox Release Repackager to other platforms ==
 
== Port the Firefox Release Repackager to other platforms ==
Line 290: Line 224:
  
 
Resources: db48x, ted
 
Resources: db48x, ted
 
== Mercurial history browsing ==
 
 
We're just starting to use an exciting new [http://betterexplained.com/articles/intro-to-distributed-version-control-illustrated/ distributed version control] tool: [http://developer.mozilla.org/en/docs/Mercurial Mercurial].
 
 
One of the exciting things about Mercurial is that the history—the list of all the changes that have ever been checked in—is not linear.  It frequently has ''branches'' and ''merges''.  This is actually a good, important feature, as you know if you've read a little about distributed version control.  The downside is that the history becomes a maze of twisty little passages.  [http://office.smedbergs.us/viewer/index.xhtml#mozilla-central:acb5456539c668d3ec0ec755dd3b64ddb56363d2 Benjamin Smedberg's demo] shows the history of a repository with lots of merges (each box is a check-in; you can click on the boxes to move around).
 
 
There have been a couple attempts at showing history in an intuitive, graphical way.  Mercurial comes with a web UI for browsing the repository, including history ([http://hg.mozilla.org/mozilla-central/index.cgi/log/13540 here's what it looks like]).  It also comes with an "hg glog" extension that draws history as ASCII art, and an "hg view" extension that does roughly the same thing with a little GUI.  Sadly, none of these applications qualifies as ''awesome''.
 
 
Your mission is to rectify this sad situation by writing an awesome browser-based UI for navigating Mercurial repository history.
 
 
Resources: jorendorff, bsmedberg
 
  
 
== Extend Try Server to test Thunderbird patches ==
 
== Extend Try Server to test Thunderbird patches ==
Line 312: Line 234:
  
 
Resources: sayrer
 
Resources: sayrer
 
== Colour Management Tests ==
 
 
Write [http://developer.mozilla.org/en/docs/Creating_reftest-based_unit_tests reftests] to compare images in order to deal with floating point tolerance.  This includes dealing with things like Monitor Profiles, profiles in JPEG (i.e., JPEGs get changed based on colour profile info).  See discussion of colour profiles in Firefox 3 [http://www.dria.org/wordpress/archives/2008/04/29/633/ here].  It would be useful to be able to compare to PNGs with a reftest, perhaps creating an image diff tool, where pixels outside a floating point tolerance (> 0.n) would somehow be highlighted so you can see what is different.  <strike>Little CMS (lcms) needs test coverage too.</strike> Done.
 
 
This will require some graphics and image knowledge (i.e., Photoshop, what colour is on a computer, etc).
 
 
Resources: #gfx, joe, vlad, bholley, [http://bholley.wordpress.com/2008/09/12/so-many-colors/ discussion of Mozilla colour profiles]
 
  
 
== Plugin Code Test Suite ==
 
== Plugin Code Test Suite ==
Line 328: Line 242:
  
 
Resources: jst
 
Resources: jst
 
== Per-Site/Per-Tab User-Agent Modification ==
 
 
Create an extension that lets a web developer modify the User-Agent string on a persistent per-site, per-tab basis.  There's already a user-agent-switcher in the FF-addons (https://addons.mozilla.org/en-US/firefox/addon/59) but it doesn't isolate the user agent per site or per tab. Strong features might include a separation of the browser identification and language support, optional persistence across browsing sessions and a UI that by default hides the UA string behind the name/version of the browser it represents.  See [http://www.webaim.org/blog/user-agent-string-history/ this] discussion of the UA's history.
 
 
Resources: mhoye
 
 
== Add Source Server Support for Mercurial ==
 
 
Previously we added [[Mozilla Source and Symbol Server|source indexing to release builds]] using CVS as a backend for pulling source files.  Since then, Mozilla has moved to Mercurial from CVS.  This project will add support so that Mercurial can be used too.  See [https://bugzilla.mozilla.org/show_bug.cgi?id=440001 bug# 440001].
 
 
Resources: ted, lsblakk
 
 
== Research PGO-related bugs ==
 
 
On Windows, Mozilla has begun using [https://bugzilla.mozilla.org/show_bug.cgi?id=419893 profile-guided optimization] to make execution of the browser faster (i.e., you run your binary and see how it is likely to run, and optimize for those code paths).  Currently, there are parts of the Mozilla source code that have bugs or crash when run in PGO builds.  This project will mean trying to isolate these bugs by doing PGO builds of these components, creating test cases, debugging, and hopefully fixing things.
 
 
Resources: ted, sdwilsh, and others based on component.
 
  
 
== Create self-serve symbol upload system ==
 
== Create self-serve symbol upload system ==
Line 353: Line 249:
 
Resources: ted
 
Resources: ted
  
== Add OpenLayers test suite to Mozilla ==
+
== <strike>Add OpenLayers test suite to Mozilla </strike>==
  
Mozilla [http://mxr.mozilla.org/mozilla-central/source/dom/tests/mochitest/ajax/ uses] many common JavaScript library test suites to add additional coverage to it's JavaScript implementation.  One test suite that is not currently used by Mozilla, but could be, is the [http://openlayers.org OpenLayer's] js [http://trac.openlayers.org/browser/trunk/openlayers/tests test suite].  See [https://bugzilla.mozilla.org/show_bug.cgi?id=399311 bug# 399311].
+
<strike>Mozilla [http://mxr.mozilla.org/mozilla-central/source/dom/tests/mochitest/ajax/ uses] many common JavaScript library test suites to add additional coverage to it's JavaScript implementation.  One test suite that is not currently used by Mozilla, but could be, is the [http://openlayers.org OpenLayer's] js [http://trac.openlayers.org/browser/trunk/openlayers/tests test suite].  See [https://bugzilla.mozilla.org/show_bug.cgi?id=399311 bug# 399311].
  
Resources: sayrer
+
Resources: sayrer</strike>
  
== Import sqlite test suite ==
+
== <strike>Import sqlite test suite</strike> ==
  
Mozilla uses an embedded version of [http://www.sqlite.org/ SQLite] extensively to [http://developer.mozilla.org/en/storage store data] such as bookmarks, history, etc.  To insure that it runs properly within Mozilla, it would be good to add the entire sqlite test suite to Mozilla's tests, so that testing the browser also means testing sqlite.  The sqlite test suite is written in TCL and needs to be ported to JavaScript.  Some [http://mxr.mozilla.org/mozilla-central/source/storage/test/unit/test_like.js work has already been done], but more is required to get full test coverage.
+
<strike>Mozilla uses an embedded version of [http://www.sqlite.org/ SQLite] extensively to [http://developer.mozilla.org/en/storage store data] such as bookmarks, history, etc.  To insure that it runs properly within Mozilla, it would be good to add the entire sqlite test suite to Mozilla's tests, so that testing the browser also means testing sqlite.  The sqlite test suite is written in TCL and needs to be ported to JavaScript.  Some [http://mxr.mozilla.org/mozilla-central/source/storage/test/unit/test_like.js work has already been done], but more is required to get full test coverage.
  
 
References: [https://bugzilla.mozilla.org/show_bug.cgi?id=391756 bug 391756], http://www.0xdeadbeef.com/weblog/?p=368
 
References: [https://bugzilla.mozilla.org/show_bug.cgi?id=391756 bug 391756], http://www.0xdeadbeef.com/weblog/?p=368
  
Resources: sdwilsh
+
Resources: sdwilsh  
 
+
</strike>
== Finish Weave/Thunderbird integration ==
 
 
 
[https://wiki.mozilla.org/Labs/Weave Weave] is Mozilla's services project.  It currently allows different Firefox installations to synchronize bookmarks, etc.  We'd like Thunderbird to be a full-fledged Weave client
 
as well.  Some [??? work has already been done], but more is required to get utility.  Possible scenarios include:
 
  
  * thunderbird accounts synchronized (configure once, use everywhere)
+
Take : [http://zenit.senecac.on.ca/wiki/index.php/Import_sqlite_test_suite Park,KiWon]
  * automatic bookmarking in Firefox of URLs sent to/from friends
 
  * access to Thunderbird address book from Firefox
 
 
 
References: [https://bugzilla.mozilla.org/show_bug.cgi?id=446444 bug 446444]
 
 
 
Resources: dmose
 
 
 
== Make Ubiquity work in Thunderbird ==
 
 
 
[http://labs.mozilla.com/2008/08/introducing-ubiquity/ Ubiquity] is a cool extensible natural language front-end to Firefox. It could do wonders in Thunderbird as well.  Aza Raskin and other Ubiquity hackers are happy to help someone do that with their Ubiquity knowledge, and #maildev will be happy to assist w/ Thunderbird knowledge.
 
 
 
Resources: aza, [http://groups.google.com/group/ubiquity-firefox ubiquity-firefox mailing list]
 
  
 
== Make chromebug work in Thunderbird ==
 
== Make chromebug work in Thunderbird ==
Line 400: Line 280:
 
Resources: Fallen
 
Resources: Fallen
  
== Contribute to Private Browsing tests ==
 
  
The new Private Browsing feature (see [https://bugzilla.mozilla.org/show_bug.cgi?id=248970 bug 248970] and the [https://wiki.mozilla.org/User:Ehsan/PrivateBrowsingTests test plan]) needs thorough tests written in order to insure its proper functionality.  This will involve collaborating with those writing the patch and tests in order to develop a full suite of tests.
 
 
Resources: ehsan, [http://www.computerworld.com/action/article.do?command=viewArticleBasic&articleId=9114486 discussion of Private Browsing]
 
 
== Create Content Security Policy test suite ==
 
 
Adding Content Restrictions functionality to Firefox means that sites could restrict types of locations for loaded scripts and other unsafe content.  The Content Security Policy is intended to mitigate a large class of Web Application Vulnerabilities: Cross Site Scripting.  In order for this to be written properly, a full test suite is required, which can test such things as inline scripts, javascript URLs, all event handler
 
attributes (onclick, etc), plugins, frames, data urls, and XBL.
 
 
References: http://people.mozilla.org/~bsterne/content-security-policy/, [https://bugzilla.mozilla.org/show_bug.cgi?id=411791 bug 411791], [https://bugzilla.mozilla.org/show_bug.cgi?id=390910 bug 390910]
 
 
Resources: bsterne, dveditz, shaver
 
  
 
== HTML page set sanitizer ==
 
== HTML page set sanitizer ==
Line 423: Line 290:
 
Resources: ted (but find someone better!)
 
Resources: ted (but find someone better!)
  
 +
== 3D object picking ==
 +
Canvas 3D JS Library is a library for the creation and manipulation of 3D scenes in the browser without needing to know much 3D programming.  Part of this project is to handle mouse input.  This particular project looks at how to perform "picking".  That is, when given a coordinate within the canvas, return the 3D object at that location.
  
 +
Resources: cathy, Andor (http://www.c3dl.org)
  
 
= Potential OOo Projects =
 
= Potential OOo Projects =
Line 440: Line 310:
  
 
Resources: humph, taras
 
Resources: humph, taras
 +
 +
== Existing Subjects proposed by OpenOffice.org Education Project  ==
 +
 +
FIXME : the projects proposed on the OpenOffice.org Education Project will be adapted to the current section.
 +
 +
Waiting we encourage you to have a look at the '''[http://wiki.services.openoffice.org/wiki/Education_Project/Effort OpenOffice.org Education Project Effort page]'''
 +
 +
Other links:
 +
 +
[http://wiki.services.openoffice.org/wiki/Education_Project  OpenOffice.org Education Project on the Wiki]
 +
 +
 +
[[User:Ericb|Ericb]] 21:05, 26 September 2008 (UTC)

Latest revision as of 13:17, 17 April 2013

Introduction

This is a list of potential projects that need people.

Students: If you'd like to work on one of these, move the chosen project to the Project List and create a page for your work based on the Sample Project template.

Open Source Community Members: We welcome your recommendations for potential projects. Please create an account on this Wiki and create a description for your proposed project below. Please list your contact info (just an IRC or FAS2 name is OK) as well as links to any related web pages as Resources for the proposed project. (Questions? Ask Chris Tyler or David Humphrey).

SBR600 Potential Projects

For possible projects for the SBR600 Software Build and Release Course, lease see the SBR600 Potential Projects page.

Potential Eclipse WTP Projects

See the list of potential bugs here.


Potential Mozilla Projects

Sample Project

This is a sample project stub. You can use the template for Sample Project in order to create a project page for one of the stubs below. This is how you 'sign-up' for a project.

NOTE: if someone has already created the project page, speak to this person and see if you can join them. If so, simply add your name to the Project Leader(s) page. Otherwise, you can become a contributor later.

Improve Localization build system

Currently it requires many many steps to produce another language of Firefox. It would really easy to package these many steps to reduce the required knowledge to generate a new language.

Adding a few make steps to wrap this process would help everyone. This is a very easy project to tackle but very benefitial if the time and love is given to it.

Reference: armenzg

Create a cross-repo pushlog to see all locales's checkins

We currently check many different repositories to trigger builds when a developer makes a change. We also check the localizer's repositories to see if they have pushed any changes. The problem is that we have close to eighty different localization repositories and that takes a long time to check each one of them. If we had a joint view that would improve our systems. An example of that view is: https://l10n-stage-sj.mozilla.org/pushes/ but the format should be more like this: http://hg.mozilla.org/mozilla-central/pushlog which is what our release engineering systems check for. This project would require you to hack hg and pushlog to make it work. armenzg has many blog posts explaining how to setup pushlog in your local machine.

Reference: armenzg - Bug 498641

Thunderbird SMTP Auto-Sensing

Modify Thunderbird so that it uses the correct SMTP server for your current network and IP. In other words, if you are at home, use your home ISP's SMTP, but if you use a school wireless network, switch to the school's SMTP. These various SMTP configurations should be manually controlled by the user, that is, you don't have to try and figure out which SMTP to use. Rather, it should be configurable in an options dialog.

References: #maildev


XULRunner Application Packaging

Help to develop an automated packaging system for XULRunner applications.

Resources: plasticmillion, mfinkle, #mozpad, #prism

'Compact databases' feature for Mozilla calendaring applications (Lightning, Sunbird)

Add the possibility to compact the database for local storage calendars based on SQLite using the VACUUM command. At the moment the local database for events and tasks will not get smaller even if you delete your tasks and events. This has serious performance implications for people, who work a lot with their calendar.

See also Bug 352976

Resources: ctalbert, daniel in #calendar on irc.mozilla.org

Spellcheck Extension for Arbitrary Web Pages

Write an extension to leverage the existing spellcheck code in Mozilla and add the ability to highlight spelling mistakes for a given web page (i.e., vs. a textbox).

Modify Firefox to handle files downloaded to Temp more appropriately

Often files downloaded by the browser are put in a temporary folder that is emptied on close. Users (and especially novice users) should be protected from inadvertent data loss as a result of important files being saved to this temp folder. This project will add fixes to the browser so that users are protected. Ideas include:

  • Make Firefox aware of common productivity file types (e.g., .doc, .pdf) and whitelist these types so they aren't deleted
  • Have office type files download automatically to a documents folder instead of temp
  • Firefox could check the timestamp of such files and delete them only if the timestamp is the same as when it was originally saved by the browser (i.e., has not been edited)
  • Warn the user on closing the browser that files are going to be removed
  • Assuming files still exist on start-up (see above), alert the user that these files are still there (similar to "New Session or Restart Existing?" dialog)
  • Have the browser pop-up a Save As dialog instead of automatically saving to temp, and use a documents path

Other ideas are possible, and a combination of these might be necessary. Ultimately, this fix should target regular users without much knowledge of the filesystem.

Resources: ted, mfinkle

See also: bug 280419 and bug 369108, and code here.

Standalone Test Harnesses

Mozilla uses several systems for automated testing, including Mochitest, Reftest, xpcshell unit tests, and crash tests. Currently, to run these test suites or develop new tests, you need to build your own Firefox with --enable-tests, and run the tests from the object directory. Ideally there would be a standalone package available for download that would let you run these test suites against any Firefox build, to ease development of new tests and allow more people to get involved with automated testing.

Add source checkout to buildbot

Unlike many open source projects, it's not possible to do a CVS checkout and build the code. This is due to the complex module and version combinations necessary to get and build a particular product, for example Firefox. To accomplish this, Mozilla uses client.mk, which provides a set of rules for getting and building the code.

Increasingly, Mozilla is moving toward using the Python based buildbot system for automated builds and tests. It would be good to add a Source class for client.mk checkouts. This would mean creating a a general Source class that understands the idea of checking out a file, and which could then be used to drive the checkout and allow for integration with client.mk.

References: Ben Hearsum (bhearsum), Rob Helmer (rhelmer)

Port the Firefox Release Repackager to other platforms

The Firefox Release Repackager allows one to take a released version of the browser, deconstruct it in order to add some custom extension, then repackage it. This allows organizations to ship slightly modified versions of stock releases, useful for their users. Currently the repackager only works on Mac.

Port this tool to Windows and/or Linux. In order to do this you'll need platform binaries of 7zip, or perhaps you can use P7zip to do a cross platform version. There are other ideas that can be added to this tool as well for making it more flexible.

Resources: mkaply, bsmedberg

gdb symbol server support

Microsoft's debugger allows the use of a symbol server, which it can use to download debugging symbols for programs and libraries. Mozilla provides this for nightly and release builds on Windows, and it's useful for people to debug their crashes locally without having to build a debug build. This functionality doesn't exist for Linux or OS X, where gdb is the debugger. gdb does support loading debug symbols from external files, so it could probably be extended to look for the symbols on a web server first.

References:

  1. https://bugzilla.mozilla.org/show_bug.cgi?id=412722#c5
  2. http://www.linuxcommand.org/man_pages/objcopy1.html (see --add-gnu-debuglink and --only-keep-debug)
  3. http://www.totalviewtech.com/Documentation/Tips/gnu_debuglink.html

Resources: ted, Stan Shebs, Jim Blandy

gdb support for minidumps for post-mortem debugging

Microsoft's debugger allows for loading a minidump produced during a crash and then performing post-mortem debugging. GDB supports using core files for the same purpose. In Firefox 3, we produce minidump files on all of our supported platforms for use with our Breakpad crash reporting system. Sometimes people may want to debug a crash locally using one of these minidumps. On Windows, using the symbol server, they can simply load the minidump in their debugger. Currently there is no equivalent on Linux or Mac. Extending gdb to support loading minidumps for post-mortem debugging would be useful. This project may rely on the gdb symbol server project to be truly useful.

References:

  1. http://code.google.com/p/google-breakpad/source/browse/trunk/src/google_breakpad/common/minidump_format.h
  2. http://www.codeproject.com/KB/debug/postmortemdebug_standalone1.aspx
  3. http://sourceware.org/gdb/current/onlinedocs/gdb_3.html#SEC7
  4. http://sourceware.org/gdb/current/onlinedocs/gdb_9.html#SEC80

Resources: ted, Stan Shebs, Jim Blandy

RegressionTry

Make it possible to look for bugs across old nightly builds of Firefox using automated tools. For example, regression-search is a script that allows you to do binary searches across binaries, looking for the existence of a bug. This could be improved through the use of tools like co-scripter. Ideally the user could look for bugs in automated ways, without having to download and install tons of browser versions.

Resources: db48x, ted

Extend Try Server to test Thunderbird patches

"Specifically, Mozilla has a great system called “try servers” where one can submit patches against the tree, and the build system runs builds on Linux, Mac and Windows, using those patches, then serves those builds for testing. This is really helpful to figure out if proposed patches solve specific problems...The only problem is that there’s a little bit of patching needed to the try server code itself to make it able to work with other targets besides Firefox, as described in bug 431375" (Ascher)

Add DTrace probes and scripts for Mozilla code base

DTrace was created by Sun in OpenSolaris to allow developers to write simple scripts in order to probe and instrument executing programs in a way not possible otherwise. One of the advantages of DTrace is that it allows you to turn on probing when you need it, but not incur an execution penalty with regard to performance (i.e., when probes aren't being scripted, they aren't run). This requires developers to add "probes" to their source code. For example, if you wanted to know when a particular function is entered/exited, get info about what happened, etc. you could add probes to the particular function. Writing the probes is not difficult, however there are hundreds or thousands of probes that Mozilla would like across its code base.

Resources: sayrer

Plugin Code Test Suite

Create a plugin test suite. There are currently no tests of any kind, and this code is very brittle and not well understood. This would involve creating a plugin or set of plugins and some html/js to drive that plugin in order to push test coverage. Maybe look at the JRE tests, create some specific plugin cases (e.g., swf to load that tests flash specific code). The newly announced Google Chromium browser seems to have something like this with regard to using the npapi for driving tests via plug-in. See also docs on IPC and plug-in design in Chromium.

This will require C programming, as well as light web development (html, js, perhaps swf).

Resources: jst

Create self-serve symbol upload system

Mozilla has a symbol server which is used by developers to debug issues in release builds that don't include debug information (i.e., symbols). However, many crashes are related to third-party binary plugins or extensions, for which Mozilla has no symbols. This project would create a web-based self-serve solution for third-parties to upload symbols for their binary components in breakpad-formatted .sym file format. Ideally this could happen in an automated way, such that third-parties could add a step to their build system to do it automatically with each release. See bug# 419879.

Resources: ted

Add OpenLayers test suite to Mozilla

Mozilla uses many common JavaScript library test suites to add additional coverage to it's JavaScript implementation. One test suite that is not currently used by Mozilla, but could be, is the OpenLayer's js test suite. See bug# 399311.

Resources: sayrer

Import sqlite test suite

Mozilla uses an embedded version of SQLite extensively to store data such as bookmarks, history, etc. To insure that it runs properly within Mozilla, it would be good to add the entire sqlite test suite to Mozilla's tests, so that testing the browser also means testing sqlite. The sqlite test suite is written in TCL and needs to be ported to JavaScript. Some work has already been done, but more is required to get full test coverage.

References: bug 391756, http://www.0xdeadbeef.com/weblog/?p=368

Resources: sdwilsh

Take : Park,KiWon

Make chromebug work in Thunderbird

TBD

Help gristmill move forward in Thunderbird

TBD

Help Calendar integration on Trunk

TBD

Resources: Fallen


HTML page set sanitizer

The Talos performance testing system at Mozilla currently runs on a large set of web pages pulled from the Alexa Top 500. These pages can't be redistributed, since they're mirrors of copyrighted web pages. In addition, many of them contain adult content. This makes it difficult for people to duplicate the Talos results or to test changes that have an expected performance impact.

A useful solution to this problem would be a tool that takes a mirrored copy of a website and "sanitizes" it, by changing the page text and image contents (making them junk or filler text or something). The caveat here is that this *cannot* change the performance characteristics of the page. For example, taking a page that is all Chinese text and replacing it with "Lorem Ipsum" filler text would cause the page to take different text rendering paths, which would change what is measured. As another example, making all JPEG images solid black would likely make them decode and render much faster. Any solution should have some analysis performed that shows that performance is not significantly altered in the sanitized page set.

Resources: ted (but find someone better!)

3D object picking

Canvas 3D JS Library is a library for the creation and manipulation of 3D scenes in the browser without needing to know much 3D programming. Part of this project is to handle mouse input. This particular project looks at how to perform "picking". That is, when given a coordinate within the canvas, return the 3D object at that location.

Resources: cathy, Andor (http://www.c3dl.org)

Potential OOo Projects

Sample Project

This is a sample project stub. You can use the template for Sample Project in order to create a project page for one of the stubs below. This is how you 'sign-up' for a project.

NOTE: if someone has already created the project page, speak to this person and see if you can join them. If so, simply add your name to the Project Leader(s) page. Otherwise, you can become a contributor later.

Generate an OOo XREF based on Dehydra

Using Dehydra, build OOo and generate an xref in the same way we are indexing for dxr.

TODO: more info....

Resources: humph, taras

Existing Subjects proposed by OpenOffice.org Education Project

FIXME : the projects proposed on the OpenOffice.org Education Project will be adapted to the current section.

Waiting we encourage you to have a look at the OpenOffice.org Education Project Effort page

Other links:

OpenOffice.org Education Project on the Wiki


Ericb 21:05, 26 September 2008 (UTC)