GSoC - Guidelines for Students
Welcome! Are you interested in working on a Google Summer of Code project with OpenMRS? We' want you to be a successful GSoC developer in our community so we've put together a few guidelines to answer some of your initial questions and help you understand what is expected of students before submitting a proposal, after being accepted, and during the coding period.
Before the Application
Become familiar with OpenMRS and the project(s) for which you're applying. If relevant, make sure you have OpenMRS installed and running. Read the Developer Guide, Getting Started as a Developer, and ask others in the community if you have questions. If you ask questions the smart way, you'll get better responses.
Make sure your development environment is installed and running, and optimized for maximum efficiency. Review our Conventions page.
Review project ideas & ask questions about those or other projects in the GSoC category on OpenMRS Talk.
Spend as much time as possible in our IRC channel or Telegram chat, as well as on OpenMRS Talk with other community members. Remember, GSoC-specific questions should be asked on Talk.
Introduce yourself on the community introduction page on OpenMRS Talk.
Achieve /dev/1 status. (earn the /dev/null badge and then earn the Smart Developer badge by passing the quiz).
Work on JIRA tickets. Pick some tickets from JIRA (#community-priority tickets, under your targeting project, or anywhere) and work on those tickets. Send the pull request with your changes to respective repository
Run, test and identity some potential issues in OpenMRS Core or modules. Create new tickets in JIRA if those are not reported yet.
Increase your visibility on OpenMRS Talk and IRC. Help others on Talk and participate in other's discussions as much as possible.
Do some code reviews. Reviewing code from others is one of the great ways to learn the OpenMRS code base. This is a must. No student will be selected who has not done code reviews.
If you're returning to do GSoC with OpenMRS for a repeat term, be just as thorough (or more so!) than first-time students. Don't skip steps and work extra hard to impress your mentor(s).
Additional expectations :
Write some blogs about OpenMRS or any related matters on OpenMRS which can help others.
Properly document your work in JIRA and help others to continue from it.
Creating the application
Take a look at the guidelines mentioned in GSoC - Proposal Guidelines when preparing your application.
Check out the recording of our session on proposal writing for some extra tips!
Communicate with the relevant mentors and community members to clarify any doubts.
Submit your application as early as possible to get feedback from the mentors, so that you can improve it before the application deadline.
After being accepted
Set up a blog for your work on open source projects, including GSoC. Post the URL on OpenMRS Talk. If you don't have a blog yet, you should create one. You will be required to write a blog post every week about your planning work and project progress during GSoC.
Contact your mentor immediately. Make a plan to communicate with them regularly. You should plan to use some combination of IRC or Telegram chat, or discussions on OpenMRS Talk (in a specific category or with a unique tag). Open source projects communicate in the open, so plan to keep any direct/private communication to an absolute minimum.
Be sure to CC your backup mentor in communications. When you email or post on Talk, be sure to CC your backup mentor so they are kept abreast of progress on your project.
Review any JIRA issues related to your project and work on some initial bugs or feature development, or work on some general OpenMRS bugs. Ask your mentor for guidance. (This doesn't mean begin your project!)
Prepare a detailed project plan together with your mentor. Browse the current OpenMRS code specific to your project and review the requirements for your project together with your mentor. Include SMART goals and schedule milestones for each week. Publish the project plan on OpenMRS Talk in the appropriate category. (Request a new subcategory if needed.)
During the coding period
Complete a short required "progress report" each week so we can make sure things are on track and there are no problems with your project. Contact organization admins any time if you have concerns about working with your mentor(s).
Write at least one blog post every week to help stay on schedule and to share your work publicly.
Commit early. Commit often. This is an important value in our open source community - read why.
Prepare mid-term & final project presentation videos about your project's status, progress, and any questions you have for the community.
You are now part of our developer community. We want you to feel like part of the team, so we expect you to:
Conduct ALL project-related discussions on IRC, Telegram, or OpenMRS Talk. (No direct emails!)
Ask questions (the smart way) if you get stuck.
Participate in our weekly Developers Forum when your schedule allows.
After GSoC
Write a final blog post summarizing your overall experience! If you like, talk to the org admins for consideration to cross-post this article to the Google Open Source Blog.
Stay involved with your project or other projects as your schedule permits! There is always plenty of development work needed for OpenMRS volunteers like you.
Continue to watch OpenMRS Talk for additional questions or feedback about your GSoC project, and for other topics that interest you.
Participate as a mentor for Google Code-in, in late 2020, should OpenMRS be accepted to participate. Your involvement will show secondary school students how they can use their skills in programming and open source projects.