Coder
GRNsight Gene Page Project Links | |||||||
---|---|---|---|---|---|---|---|
Overview | Deliverables | Reference Format | Guilds | Project Manager | Quality Assurance | Data Analysis | Coder |
Teams | Page Desiigner | Lights, Camera, InterACTION! | Gene hAPI | JASPAR the Friendly Ghost |
The coder is the resident expert on the technology being used—assorted software, file management, version control, troubleshooting, programming. He or she coordinates with Drs. Dahlquist and Dionisio and fellow coders in developing the code base for the GRNsight gene page. GRNsight is written in JavaScript and is built on open source JavaScript libraries. Source code is hosted on GitHub and managed by Node.js.
Contents
Guild Members
- Page Design: Arash (Coder), Nicole (Designer)
- Gene Database APIs: Eddie A. and John
- JASPAR API: Eddie B. and Simon
- Interaction and Integration: Blair and Zach
Milestones
The milestones do not necessarily correspond to particular weeks; instead they are sets of tasks grouped together. However, Milestones 1-3 are hard prerequisites for proceeding to Milestone 4, so ideally the Coder guild should finish these milestones (they require some coordination; see below) as soon as possible. The Coder guild should be working within the Milestone 4-5 cycle by Week 12 at the latest.
Milestone 0: Journal Club Presentation
- For the Week 11 assignment, the Coders (including Designers) of each team will prepare a PowerPoint presentation of their respective assigned software design/development/engineering/best practices reading to be delivered in class on Tuesday, November 14.
Milestone 1: Working Environment Setup
Coder work will require the following software. The Seaver 120 lab computers are already set up for this; this list is provided for Coders who need to work on a different computer or outside of the lab.
- Node.js 8.4.0 or newer
- Code-savvy editor such as Atom or Microsoft Visual Studio Code
- Web browser with developer tools (Seaver 120 uses Google Chrome)
- git version control software
- (depends on team) curl command
Make sure that this software is installed and operational before beginning. If any Coder needs help with any of these packages, please consult your fellow guild members or ask Dr. Dionisio.
Milestone 2: Version Control Setup
Coding work will be done on a fork of the open source GRNsight project, which is hosted on GitHub. The software that interacts with GitHub to perform version control is git. If any Coder needs help with git or version control concepts in general, please consult your fellow guild members or ask Dr. Dionisio.
The Interaction and Integration team is responsible for this fork, and will do their own work on the master branch of this fork. Thus, many of the early steps in this procedure involve them, and they must accomplish these steps first before the others can proceed:
- All members of the Coder guild should acquire a GitHub account, if they don’t already have one (it’s free).
- One of the Coders of the Interaction and Integration team creates a fork of the GRNsight project.
- The Interaction and Integration team adds the GitHub accounts of all Coder guild members as collaborators on the fork.
- Once every team is a collaborator on this fork, they can then create their respective branches on the fork:
- The Page Design team creates a branch called page-design.
- The Gene Database APIs team creates a branch called gene-database-apis.
- After the gene-database-apis branch is created, the JASPAR API team creates a branch from gene-database-apis called jaspar-api.
The teams will then do their work on their respective branches. The protocol for integrating your work is described in the Integration and Testing milestone below.
The structure described in this milestone is a typical GitHub fork-and-branch approach which some Coders are already familiar with. If any Coder needs help with this methodology, please consult your fellow guild members or ask Dr. Dionisio.
Milestone 3: “Developer Rig” Setup and Initial As-Is Build
Before development can begin in earnest, the following initial setup steps must be performed per Coder after version control setup is complete:
- git clone the GitHub fork created in the version control setup milestone on where you plan to work on the project.
- cd into the folder that contains the cloned repository
- git checkout the branch that is assigned to you:
- Interaction and Integration: master (no need for an explicit checkout because the clone defaults to this branch)
- Page Design: page-design
- Gene Database APIs: gene-database-apis
- JASPAR: jasper-api (note that as instructed above, this should be a branch of the gene-database-apis branch)
- Follow the instructions in the GRNsight wiki to perform the following:
- Installation of necessary third-party libraries
- Initial startup of the GRNsight application on your computer
If anyone runs into problems with this procedure, please consult with your fellow guild members or notify Dr. Dionisio.
Milestone 4: Development and Implementation
(varies per team)
Milestone 5: Integration and Testing
GRNsight Gene Page Project Links | |||||||
---|---|---|---|---|---|---|---|
Overview | Deliverables | Reference Format | Guilds | Project Manager | Quality Assurance | Data Analysis | Coder |
Teams | Page Desiigner | Lights, Camera, InterACTION! | Gene hAPI | JASPAR the Friendly Ghost |