mirror of
https://github.com/fnproject/fn.git
synced 2022-10-28 21:29:17 +03:00
update ruby helloworld
This commit is contained in:
@@ -34,6 +34,10 @@ curl -H "Content-Type: application/json" -X POST -d @hello.payload.json http://l
|
|||||||
|
|
||||||
That's it!
|
That's it!
|
||||||
|
|
||||||
|
### Note on Dependencies
|
||||||
|
|
||||||
|
In Go, simply put them all in the `vendor/` directory.
|
||||||
|
|
||||||
# In Review
|
# In Review
|
||||||
|
|
||||||
1. We piped JSON data into the function at the command line
|
1. We piped JSON data into the function at the command line
|
||||||
@@ -56,5 +60,6 @@ That's it!
|
|||||||
log.Println("here")
|
log.Println("here")
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
# Next Up
|
# Next Up
|
||||||
## [Tutorial 2: Input Parameters](examples/tutorial/params)
|
## [Tutorial 2: Input Parameters](examples/tutorial/params)
|
||||||
@@ -1,27 +1,43 @@
|
|||||||
## Quick Example for a Ruby Function (4 minutes)
|
# Tutorial 1: Ruby Function w/ Input (3 minutes)
|
||||||
|
|
||||||
This example will show you how to test and deploy a Ruby function to Oracle Functions.
|
This example will show you how to test and deploy Ruby code to Oracle Functions. It will also demonstrate passing data in through stdin.
|
||||||
|
|
||||||
|
### First, run the following commands:
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
# create your func.yaml file
|
# Initialize your function creating a func.yaml file
|
||||||
fn init <YOUR_DOCKERHUB_USERNAME>/hello
|
fn init <DOCKERHUB_USERNAME>/hello
|
||||||
# install dependencies, we need the json gem to run this
|
|
||||||
docker run --rm -it -v ${pwd}:/worker -w /worker funcy/ruby:dev bundle install --standalone --clean
|
# Test your function.
|
||||||
# build the function
|
# This will run inside a container exactly how it will on the server. It will also install and vendor dependencies from Gemfile
|
||||||
fn build
|
fn run
|
||||||
# test it
|
|
||||||
|
# Now try with an input
|
||||||
cat hello.payload.json | fn run
|
cat hello.payload.json | fn run
|
||||||
# push it to Docker Hub
|
|
||||||
fn push
|
# Deploy your functions to the Oracle Functions server (default localhost:8080)
|
||||||
# Create a route to this function on Oracle Functions
|
# This will create a route to your function as well
|
||||||
fn routes create myapp /hello
|
fn deploy myapp
|
||||||
|
```
|
||||||
|
### Now call your function:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
curl http://localhost:8080/r/myapp/hello
|
||||||
```
|
```
|
||||||
|
|
||||||
Now surf to: http://localhost:8080/r/myapp/hello
|
Or call from a browser: [http://localhost:8080/r/myapp/hello](http://localhost:8080/r/myapp/hello)
|
||||||
|
|
||||||
## Dependencies
|
And now with the JSON input:
|
||||||
|
|
||||||
Create a [Gemfile](http://bundler.io/gemfile.html) file in your function directory, then run:
|
```sh
|
||||||
|
curl -H "Content-Type: application/json" -X POST -d @hello.payload.json http://localhost:8080/r/myapp/hello
|
||||||
|
```
|
||||||
|
|
||||||
|
That's it!
|
||||||
|
|
||||||
|
### Note on Dependencies
|
||||||
|
|
||||||
|
In Ruby, we create a [Gemfile](http://bundler.io/gemfile.html) file in your function directory, then run:
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
docker run --rm -it -v ${pwd}:/worker -w /worker funcy/ruby:dev bundle install --standalone --clean
|
docker run --rm -it -v ${pwd}:/worker -w /worker funcy/ruby:dev bundle install --standalone --clean
|
||||||
@@ -38,7 +54,43 @@ Open `func.rb` to see it in action.
|
|||||||
To update dependencies:
|
To update dependencies:
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
docker run --rm -it -v ${pwd}:/worker -w /worker funcy/ruby:dev bundle update
|
# Let's run bundle update
|
||||||
# then install again to vendor them
|
docker run --rm -it -v ${PWD}:/worker -w /worker funcy/ruby:dev bundle update
|
||||||
docker run --rm -it -v ${pwd}:/worker -w /worker funcy/ruby:dev bundle update
|
|
||||||
|
# Then bundle install again to vendor them
|
||||||
|
docker run --rm -it -v ${PWD}:/worker -w /worker funcy/ruby:dev bundle install --standalone --clean
|
||||||
```
|
```
|
||||||
|
|
||||||
|
# In Review
|
||||||
|
|
||||||
|
1. We piped JSON data into the function at the command line
|
||||||
|
```sh
|
||||||
|
cat hello.payload.json | fn run
|
||||||
|
```
|
||||||
|
|
||||||
|
2. We received our function input through **stdin**
|
||||||
|
```ruby
|
||||||
|
payload = STDIN.read
|
||||||
|
```
|
||||||
|
|
||||||
|
3. We wrote our output to **stdout**
|
||||||
|
```ruby
|
||||||
|
puts "Hello #{name} from Ruby!"
|
||||||
|
```
|
||||||
|
|
||||||
|
4. We sent **stderr** to the server logs
|
||||||
|
```ruby
|
||||||
|
STDERR.puts
|
||||||
|
```
|
||||||
|
|
||||||
|
5. We enabled our Ruby gem dependencies using `require_relative`
|
||||||
|
```ruby
|
||||||
|
require_relative 'bundle/bundler/setup'
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
# Next Up
|
||||||
|
## [Tutorial 2: Input Parameters](examples/tutorial/params)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -9,4 +9,6 @@ if payload != ""
|
|||||||
name = payload['name']
|
name = payload['name']
|
||||||
end
|
end
|
||||||
|
|
||||||
puts "Hello #{name} from Ruby!"
|
puts "Hello #{name}!"
|
||||||
|
|
||||||
|
STDERR.puts "---> STDERR goes to server logs"
|
||||||
|
|||||||
Reference in New Issue
Block a user