Skip to content

Latest commit

 

History

History
239 lines (144 loc) · 8.21 KB

common.md

File metadata and controls

239 lines (144 loc) · 8.21 KB

Common

This section outlines common guidelines and best practices for engineers of all specializations.

In a nutshell

Find more details about each point below.

User Experience

  • Follow platform-specific User Interface Guidelines
  • Never block User Interface of your app:
    • perform network requests in background
    • do all database work in background
    • etc
  • If something is happening in background, let user know about it (show activity indicator, progress bar etc)

Error Handling

Try to cover all the critical cases when you write error handling code.

For instance, handle not only HTTP 200 OK response status, take care of 401, 403, 404, 500-504 and others.

Exception Handling

Handle exceptions properly.

Bad:

    try {
        doSomethingDangerous();
    }
    catch (Exception e) {
        Log(e.printStackTrace());
    }

Good:

    try {
        doSomethingDangerous();
    }
    catch (ConcreteException e) {
        logErrorMessage(e);
        closeNetworkConnections();
        closeDatabaseConnections();
        freeOtherResources();
        showComprehensiveErrorMessage(e); // or showSendCrashReportDialog();
        gracefullyTerminateTheApp();
    }
    catch (OtherConcreteException e) {
        // ...
    }

Personal Data Security

Never store user's login credentials, credit card details and other potentially vulnerable personal information on mobile devices or in web browser local storage.

Non-stable Components

Never use non-stable versions of components (SDKs, frameworks, libraries, gems, pods, jars etc) in a production code.

Non-stable versions are:

  • alpha, beta (v2.0-alpha)
  • nightly builds (v0.10.12-nightly-20130615)
  • release candidates (v1.0-rc1 etc)

You can use non-stable versions for research projects, proof of concept, or your own skill-up.

Deprecated API

Never use API classes, methods or functions marked as “Deprecated”.

Don’t Reinvent The Wheel

Before start to work on new non-trivial problem, check if the solution already available. Do not hesitate to use solutions from your teammates or third-party components, libraries and frameworks (either open-source or proprietary).

On the other hand, think twice before using the third-party component:

  • is it good enough or poorly designed/written?
  • isn't it an overkill/redundant?

Don't Use Outdated Source Components

Don't use frameworks, libraries, SDKs and other source code which is outdated or does not have active support community.

For instance, don't use CanCan gem which is not supported anymore. Use CanCanCan instead.

Another example. For Dependency Injection in Android, don't use outdated Dagger 1, use Dagger 2 instead.

Licenses

If you are going to use a third-party component in your project, check its license first. You can use a component with permissive type of license (e.g. BSD, MIT, Apache) with no doubts. For other licenses, discuss and agree the usage of component with Project Manager and Client.

Useful web site: http://choosealicense.com/

Networking

  • Communicate via secured connection
  • Use industry standard technologies for authentication
  • Develop and use RESTful web services
  • Prefer JSON to XML

Secured Connection

For production-mode apps (both mobile and web), establish TLS-secured network connection.

Authentication

Never use HTTP Basic Authentication or other authentication methods that transfer credentials as a plain text.

Use industry standard authentication methods: at least HTTP Digest Authentication, OAuth 2.0 is preferred.

RESTful Web Services

REST architectural style is a standard de-facto for modern web services development.

If you are web developer, don’t reinvent the square wheel - develop RESTful web services for your clients (i.e., another developers).

If you are not web developer - don’t hesitate to tell the web developer to not reinvent the square wheel if one proposes something weird instead of RESTful web services.

More info:

JSON vs. XML

JSON format is simpler than XML.

JSON serialization and parsing is supported on all platforms we develop apps for, so it is good for communication between our apps.

Minimum development efforts required to add JSON support to a project. JSON support works out of the box in most platforms.

Source Code Management

We use Git for source code management.

Please read about the practices we follow in a Git section of this document.

We have a GitLab-powered server to keep projects we develop for our clients:

We have a GitHub account for open-source projects:

We can work with client's repositories upon request. We have experience with Bitbucket and GitHub repository hostings and CVS, Subversion and Mercurial SCMs.

Continuous Integration

We use Jenkins and GitLab CI for Continuous Integration.

Each app of the project should have at least 2 build configurations in Continuous Integration system (either Jenkins or GitLab CI):

  • nightly - builds are running every night, fetching the latest source from develop branch of Git repository.
  • stable - builds are running when changes available in master branch of Git repository.

For more information on platform-specific set up, check the corresponding sections of this document.

Our servers:

Jenkins + Dropbox

If the application build file (IPA, APK etc) is too large to send by email, use dropbox_uploader.sh script that is already installed on our Jenkins servers.

Add “Execute Shell” build step to the configuration:

${JENKINS_HOME}/dropbox_uploader.sh upload path_to_build_file dropbox_destination_path

where

  • path_to_build_file - path to the app build
  • dropbox_destination_path - path to a directory in MLSDev Dropbox account, where you want a build to be uploaded. This path should be like Projects/<Manager's Name>/<Project Name>/Builds/<Debug or Release>/

Script is taken from Dropbox-Uploader

Product Versioning

Track product version numbers and keep them up-to-date. See Versioning section for details.

Code Review

Code Review should be performed for every project on regular basis.

Please read about our Code Review process here.

Use Docker

When appropriate, prefer to use Docker for development, staging and production environments.

See Docker section for more information.