-
Notifications
You must be signed in to change notification settings - Fork 249
Bugs and features
We use GitHub's issues feature to track our ever-longer TODO list for the Adapt project. This includes bugs, new features, discussion points, and anything else code-related that needs attention. In an attempt to make everyone's lives easier, we've only turned on the issues for the adapt_framework repository, and use labels to filter the different areas.
As you'll soon find out, we have a healthy collection of bugs and feature requests in our pot. To make browsing these as painless as possible, we try to add useful labels such as accessibility to make filtering a bit easier.
Read on for a checklist of dos and don'ts regarding logging issues.
If you think you’ve found a bug, there are a few things to consider before logging a new issue:Can you replicate it? If the answer to this is no, please think carefully before logging an issue. Although we take bugs seriously, our development time is limited and we can’t afford to spend it failing to replicate bugs.
Has the issue been reported before? We have already built up a sizeable back-log of issues, so the issue may have been reported by someone already. Please do therefore search the list of issues first. If it has already been reported, any extra information you have garnered from your own tests could be invaluable in fixing it, so please add any such info to the existing ticket, should you find one.
Is it covered? By this we mean: is your set-up listed in the v2.0.0 standards definitions document? In an ideal world, we’d commit to supporting Adapt on all browsers and operating systems. Unfortunately this isn’t feasible with the resources we have, so we have to prioritise those named in the standards definition.
If your bug passes the above tests, the next step is to create an issue.
Try to give your issue a succinct name. Something short, but which still give the reader a good summary of the problem without needing to open the issue. Also try to reference the plugin name (if applicable) - leave out the adapt-contrib
prefix where possible to cut down on characters 😄
The main body of the issue needs to contain as much detail as possible about the bug you can provide. This should focus on the following:
A description of the bug, steps on how to replicate it and your set up (i.e. browser and operating system - aboutmybrowser can be useful here). Feel free to include any other information which you think may be useful, screenshots in particular can often give more useful information than words alone!
Make a note of any JavaScript errors you see. You may need to press F12 to reveal your browser's developer tools. If you are testing using a tablet or smartphone you will need to connect it to your PC or Mac in order to get access to the developer tools.
If your bug depends upon certain configuration options in order to be replicable, it is vital that you state these (or copy the require JSON into the issue and mark as a codeblock - GitHub issues support markdown).
If there's a feature you'd like to see in Adapt, we'd love to hear from you!
We manage feature requests in the same way as issues, so much of the above applies. The most important thing to remember when requesting a new feature, is to add feature-request
to the Labels field (you might also want to give a more appropriate Issue type than Bug!).
Try to give as much detail about your request as you can in the description, as this will give us the best idea of what you want. It would also be beneficial to leave you GitHub username, so we can get in touch with you if we implement your feature.
A few of the fields mentioned above won't be applicable to feature requests, so feel free to leave those blank.
We are always grateful for any time you have to contribute to the Adapt project. Depending on your experience level and confidence, there are a number of ways you can begin contributing.
Fixing bugs is a great way to dip your toe into the warm Adapt waters. Head to the relevant repo's issues page and look for issues with the good-first-bug or mentored-bug labels for some more straightforward tasks. The former should be accessible to developers of any experience level, while the latter may require some more metaphorical hand-holding from one of the core development team.
If you're confident working with the framework on a larger scale, why not grab a feature-request issue and give that a go?
Regardless of the feature, there will probably be some discussion amongst the community/core team needed before you can get knee-deep in code. It's a good idea therefore to head to Gitter to get the ball rolling and give everyone a heads-up on what you're thinking of doing so we can advise you on the best route to take. Also be sure to have a look at our guide to contributing code, which has some handy tips!
If you have any questions which haven't been answered here, please have a look through the official GitHub issue documentation, or ask the community in one of our Gitter rooms.
- Framework in Five Minutes
- Setting up Your Development Environment
- Manual Installation of the Adapt Framework
- Adapt Command Line Interface
- Common Issues
- Reporting Bugs
- Requesting Features
- Creating Your First Course
- Styling Your Course
- Configuring Your Project with config.json
- Content starts with course.json
- Course Localisation
- Compiling, testing and deploying your Adapt course
- Core Plugins in the Adapt Learning Framework
- Converting a Course from Framework Version 1 to Version 2
- Contributing to the Adapt Project
- Git Flow
- Adapt API
- Adapt Command Line Interface
- Core Events
- Core Model Attributes
- Core Modules
- Web Security Audit
- Peer Code Review
- Plugins
- Developing Plugins
- Developer's Guide: Components
- Developer's Guide: Theme
- Making a theme editable
- Developer's Guide: Menu
- Registering a Plugin
- Semantic Version Numbers
- Core Model Attributes
- Adapt Command Line Interface
- Accessibility v3
- Adapt Framework Right to Left (RTL) Support