Skip to content

Latest commit

 

History

History
89 lines (54 loc) · 2.09 KB

CONTRIBUTING.md

File metadata and controls

89 lines (54 loc) · 2.09 KB

Contributing to Fn

Start Here

We're excited that you're interested in contributing to the Fn Project! Please see the general project contributing guidelines page first!

Fn Server (this repo) Specifics

The Fn Server is only for the essential parts of the entire Fn ecosystem.

These include:

  • The core API (apps, routes, calls, logs)
  • Executing functions (sync)
  • Extension points (callbacks, middleware, API additions)

This does not include:

  • authentication
  • stats/metrics
  • special/optional features such as triggers, fdk's, workflows, event sources, etc.
  • could be argued that additional I/O formats beyond the basic ones we support should be built as plugins too

Rule of thumb: If it could be built as an extension, then build it as an extension.

We WILL accept any reasonable additions to extension points in order to support building extensions.

We WILL do whatever we can to make it easy for users to add extensions (easy builds or use Go plugins).

Graduation: Some extensions can graduate into core if they become commonplace in the community (ie: majority of users are using it).

How to Build and Run the Fn Server

Build Dependencies

Getting the Repository

$ git clone https://github.com/fnproject/fn.git

See contributing guide for pointers about making changes to fn (ie forking). Note that you must clone fnproject's repo, and not your fork, in order for the build to work.

Build

Requires Go >= 1.11.0 for go mod support

Change to the correct directory (if not already there):

$ cd path/to/fnproject/fn

Then after every change, run:

make run

or just build:

make build

This builds and runs the fn binary. It will start Fn using an embedded sqlite3 database running on port 8080.

Test

make test

Run in Docker

Start Fn inside a Docker container:

make docker-run

Tests in Docker

Run tests inside a Docker container:

make docker-test