perl-heroku
===========

####  Sun Sep  2 22:12:10 EDT 2012
 ### follow:
  http://blog.kraih.com/mojolicious-in-the-cloud-hello-heroku
  https://github.com/judofyr/perloku

####  Mon Sep  3 01:24:17 EDT 2012
 ### perl heroku example, push to https://github.com/phelanm/perl-heroku.git
  mjp@uberwald:~/src/heroku/perl-heroku$ git config --global user.name "mark phelan"
  mjp@uberwald:~/src/heroku/perl-heroku$ git config --global user.email phelanm@gmail.com
  mjp@uberwald:~/src/heroku/perl-heroku$ git remote add origin https://github.com/phelanm/perl-heroku.git
     git remote add origin https://github.com/phelanm/perl-heroku.git
  mjp@uberwald:~/src/heroku/perl-heroku$    git push -u origin master
   Username for 'https://github.com': phelanm
   Password for 'https://phelanm@github.com': ***
   Branch master set up to track remote branch master from origin.
   Everything up-to-date
  mjp@uberwald:~/src/heroku/perl-heroku$ git add Makefile.PL Perloku myapp.pl 
  mjp@uberwald:~/src/heroku/perl-heroku$ git add README.md
  mjp@uberwald:~/src/heroku/perl-heroku$ git status
   # On branch master
   # Changes to be committed:
   #   (use "git reset HEAD <file>..." to unstage)
   #
   #	new file:   Makefile.PL
   #	new file:   Perloku
   #	modified:   README.md
   #	new file:   myapp.pl
  mjp@uberwald:~/src/heroku/perl-heroku$    git push -u origin master
   Username for 'https://github.com': phelanm
   Password for 'https://phelanm@github.com': ***
   Branch master set up to track remote branch master from origin.
   Everything up-to-date
  mjp@uberwald:~/src/heroku/perl-heroku$ git init
   Reinitialized existing Git repository in /home/mjp/src/heroku/perl-heroku/.git/
  mjp@uberwald:~/src/heroku/perl-heroku$ git commit -m "Mojolicious::Lite helloworld" .
   [master dabf5d9] Mojolicious::Lite helloworld
    4 files changed, 20 insertions(+), 1 deletion(-)
    create mode 100644 Makefile.PL
    create mode 100755 Perloku
    create mode 100755 myapp.pl
  mjp@uberwald:~/src/heroku/perl-heroku$ git status
   # On branch master
   # Your branch is ahead of 'origin/master' by 1 commit.
   #
   nothing to commit (working directory clean)
  mjp@uberwald:~/src/heroku/perl-heroku$ git push -u origin master
   Username for 'https://github.com': phelanm
   Password for 'https://phelanm@github.com': ***
   
   Counting objects: 8, done.
   Delta compression using up to 2 threads.
   Compressing objects: 100% (6/6), done.
   Writing objects: 100% (6/6), 773 bytes, done.
   Total 6 (delta 0), reused 0 (delta 0)
   To https://github.com/phelanm/perl-heroku.git
      8ac442b..dabf5d9  master -> master
   Branch master set up to track remote branch master from origin.
 
 ### perl heroku example, push to heroku
  ##  follow: https://github.com/judofyr/heroku-buildpack-hello
   #   initial attempt to deploy on heroku
    mjp@uberwald:~/src/heroku/perl-heroku$ heroku create -s cedar --buildpack http://github.com/phelanm/perl-heroku.git
     Creating murmuring-basin-9623... done, stack is cedar
     BUILDPACK_URL=http://github.com/phelanm/perl-heroku.git
     http://murmuring-basin-9623.herokuapp.com/ | git@heroku.com:murmuring-basin-9623.git
     Git remote heroku added
    
    mjp@uberwald:~/src/heroku/perl-heroku$ # vi Perloku Makefile.PL
 
    mjp@uberwald:~/src/heroku/perl-heroku$ git push heroku master
     Counting objects: 9, done.
     Delta compression using up to 2 threads.
     Compressing objects: 100% (7/7), done.
     Writing objects: 100% (9/9), 963 bytes, done.
     Total 9 (delta 0), reused 0 (delta 0)
     
     -----> Heroku receiving push
     -----> Fetching custom buildpack... cloning with git...done
      !     Heroku push rejected, no Cedar-supported app detected
     
     To git@heroku.com:murmuring-basin-9623.git
      ! [remote rejected] master -> master (pre-receive hook declined)
     error: failed to push some refs to 'git@heroku.com:murmuring-basin-9623.git'
   #   update files to match heroku-buildpack-hello
    mjp@uberwald:~/src/heroku/perl-heroku$ git status
     # On branch master
     nothing to commit (working directory clean)
   #   setup carton
    mjp@uberwald:~/src/heroku/perl-heroku$ sudo apt-get install carton
     ...
     The following NEW packages will be installed:
       carton cpanminus libcapture-tiny-perl libclass-data-inheritable-perl
       libcpan-distnameinfo-perl libcpan-meta-perl libcpan-meta-requirements-perl
       libcpan-meta-yaml-perl libdevel-stacktrace-perl libexception-class-perl
       libjson-perl libjson-pp-perl liblocal-lib-perl libmodule-cpanfile-perl
       libparse-cpan-meta-perl libtry-tiny-perl
     0 upgraded, 16 newly installed, 0 to remove and 2 not upgraded.
     ...
    mjp@uberwald:~/src/heroku/perl-heroku$ git add carton.lock
     fatal: pathspec 'carton.lock' did not match any files
    mjp@uberwald:~/src/heroku/perl-heroku$ carton
     Installing modules using carton.lock (deployment mode)
     Can't use an undefined value as a HASH reference at /usr/share/perl5/Carton.pm line 78.
    mjp@uberwald:~/src/heroku/perl-heroku$ carton install
     Installing modules using carton.lock (deployment mode)
     Can't use an undefined value as a HASH reference at /usr/share/perl5/Carton.pm line 78.
    mjp@uberwald:~/src/heroku/perl-heroku$ cat cpanfile 
     requires 'Plack', 0.9980;
     requires 'Starman', 0.2000;
    mjp@uberwald:~/src/heroku/perl-heroku$ carton install
     Installing modules using cpanfile
     ! Couldn't find module or a distribution Plack (0.998)
     ! Couldn't find module or a distribution Starman (0.2)
     Installing modules failed
    mjp@uberwald:~/src/heroku/perl-heroku$ sudo apt-get install starman
     ...
     The following NEW packages will be installed:
       libclass-inspector-perl libdata-dump-perl libdevel-stacktrace-ashtml-perl
       libfile-sharedir-perl libfilesys-notify-simple-perl libhash-multivalue-perl
       libhttp-body-perl libhttp-parser-xs-perl libio-multiplex-perl
       libio-socket-inet6-perl libmodule-refresh-perl libnet-cidr-perl
       libnet-server-perl libparams-util-perl libpath-class-perl libplack-perl
       libsocket6-perl libtest-requires-perl libtest-sharedfork-perl
       libtest-tcp-perl libyaml-perl starman
     0 upgraded, 22 newly installed, 0 to remove and 2 not upgraded.
     ...
    mjp@uberwald:~/src/heroku/perl-heroku$ carton install
     Installing modules using cpanfile
     Successfully installed ExtUtils-MakeMaker-6.62 (upgraded from 6.57_05)
     Successfully installed Test-Requires-0.06
     Successfully installed Try-Tiny-0.11
     Successfully installed Hash-MultiValue-0.12
     Successfully installed URI-1.60
     Successfully installed Devel-StackTrace-1.27
     Successfully installed Test-Tester-0.108
     Successfully installed Test-NoWarnings-1.04
     Successfully installed Test-Deep-0.110
     Successfully installed LWP-MediaTypes-6.02
     Successfully installed Encode-Locale-1.03
     Successfully installed HTTP-Date-6.02
     Successfully installed HTML-Tagset-3.20
     Successfully installed HTML-Parser-3.69
     Successfully installed HTTP-Message-6.03
     Successfully installed HTTP-Body-1.15
     Successfully installed Test-SharedFork-0.20
     Successfully installed Test-TCP-1.17
     Successfully installed Class-Inspector-1.27
     Successfully installed File-ShareDir-1.03
     Successfully installed Filesys-Notify-Simple-0.08
     Successfully installed HTTP-Negotiate-6.01
     Successfully installed File-Listing-6.04
     Successfully installed HTTP-Daemon-6.01
     Successfully installed Net-HTTP-6.03
     Successfully installed HTTP-Cookies-6.01
     Successfully installed WWW-RobotRules-6.02
     Successfully installed libwww-perl-6.04
     Successfully installed Devel-StackTrace-AsHTML-0.11
     Successfully installed Plack-1.0003
     Successfully installed Net-Server-2.006
     Successfully installed HTTP-Parser-XS-0.14
     Successfully installed Data-Dump-1.21
     Successfully installed Starman-0.3001
     34 distributions installed
     Complete! Modules were installed into local
    mjp@uberwald:~/src/heroku/perl-heroku$ git add cpanfile carton.lock
    mjp@uberwald:~/src/heroku/perl-heroku$ git commit -m "add Plack and Starman"
     [detached HEAD ec561a9] add Plack and Starman
      2 files changed, 3150 insertions(+)
      create mode 100644 carton.lock
      create mode 100644 cpanfile
    mjp@uberwald:~/src/heroku/perl-heroku$ carton exec -Ilib -- starman -p 8080 myapp.psgi
     2012/09/02-23:10:02 Starman::Server (type Net::Server::PreFork) starting! pid(22754)
     Resolved [*]:8080 to [0.0.0.0]:8080, IPv4
     Binding to TCP port 8080 on host 0.0.0.0 with IPv4
     Setting gid to "1000 1000 20 24 25 29 30 44 46 100 102 104 109 1000"
     Error while loading myapp.psgi: No such file or directory at (eval 19) line 4.
    mjp@uberwald:~/src/heroku/perl-heroku$ carton exec -Ilib -- starman -p 8080 myapp.pl 
     2012/09/02-23:10:20 Starman::Server (type Net::Server::PreFork) starting! pid(23692)
     Resolved [*]:8080 to [0.0.0.0]:8080, IPv4
     Binding to TCP port 8080 on host 0.0.0.0 with IPv4
     Setting gid to "1000 1000 20 24 25 29 30 44 46 100 102 104 109 1000"
     Error while loading myapp.pl: Can't locate Mojolicious/Lite.pm in @INC (@INC contains: lib local/lib/perl5/x86_64-linux-gnu-thread-multi local/lib/perl5 . /usr/share/perl/5.14 /usr/lib/perl/5.14) at myapp.pl line 2.
    mjp@uberwald:~/src/heroku/perl-heroku$ sudo apt-get install libmojolicious-perl libmojolicious-plugin-basicauth-perl libtest-www-mechanize-mojo-perl
     ...
     The following NEW packages will be installed:
       libcarp-assert-more-perl libcarp-assert-perl libhtml-form-perl
       libhttp-daemon-perl libhttp-server-simple-perl libjs-jquery
       libmojolicious-perl libmojolicious-plugin-basicauth-perl
       libtest-longstring-perl libtest-www-mechanize-mojo-perl
       libtest-www-mechanize-perl libwww-mechanize-perl
     0 upgraded, 12 newly installed, 0 to remove and 2 not upgraded.
     ...
    mjp@uberwald:~/src/heroku/perl-heroku$ carton exec -Ilib -- starman -p 8080 myapp.pl 
     2012/09/02-23:15:14 Starman::Server (type Net::Server::PreFork) starting! pid(27141)
     Resolved [*]:8080 to [0.0.0.0]:8080, IPv4
     Binding to TCP port 8080 on host 0.0.0.0 with IPv4
     Setting gid to "1000 1000 20 24 25 29 30 44 46 100 102 104 109 1000"
     Error while loading myapp.pl: Can't locate Mojolicious/Lite.pm in @INC (@INC contains: lib local/lib/perl5/x86_64-linux-gnu-thread-multi local/lib/perl5 . /usr/share/perl/5.14 /usr/lib/perl/5.14) at myapp.pl line 2.
     ...
    mjp@uberwald:~/src/heroku/perl-heroku$ sudo updatedb
    mjp@uberwald:~/src/heroku/perl-heroku$ locate Lite.pm
     /usr/lib/perl5/DBD/SQLite.pm
     /usr/share/perl/5.14.2/CPANPLUS/Internals/Source/SQLite.pm
     /usr/share/perl5/Mojolicious/Lite.pm
    mjp@uberwald:~/src/heroku/perl-heroku$ carton install
     Installing modules using cpanfile
     You have Plack (1.0003)
     You have Starman (0.3001)
     Complete! Modules were installed into local
    cat /usr/share/perl5/Mojolicious.pm
     ...
     our $VERSION  = '2.98';
     ...
    vi ~/src/heroku/perl-heroku/cpanfile
     requires 'Plack', 0.9980;
     requires 'Starman', 0.2000;
     requires 'Mojolicious', 2.98;
    mjp@uberwald:~/src/heroku/perl-heroku$ carton install
     Installing modules using cpanfile
     You have Plack (1.0003)
     You have Starman (0.3001)
     Successfully installed Mojolicious-3.36
     1 distribution installed
     Complete! Modules were installed into local
    man carton
     ...
              # On your development environment
              > cat cpanfile
              requires 'Plack', 0.9980;
              requires 'Starman', 0.2000;
     
              > carton install
              > git add cpanfile carton.lock
              > git commit -m "add Plack and Starman"
     
              # Other developer's machine, or on a deployment box
              > carton install
              > carton exec -Ilib -- starman -p 8080 myapp.psgi
     ...
    mjp@uberwald:~/src/heroku/perl-heroku$ carton exec -Ilib -- starman -p 8080 myapp.pl 
     2012/09/02-23:26:00 Starman::Server (type Net::Server::PreFork) starting! pid(29849)
     Resolved [*]:8080 to [0.0.0.0]:8080, IPv4
     Binding to TCP port 8080 on host 0.0.0.0 with IPv4
     Setting gid to "1000 1000 20 24 25 29 30 44 46 100 102 104 109 1000"
     ...
    
      mjp@uberwald:~/notes$ curl "http://localhost:8080"
       Hello phelanm Mojo!
    
     ...
     [Sun Sep  2 23:27:04 2012] [debug] Your secret passphrase needs to be changed!!!
     [Sun Sep  2 23:27:04 2012] [debug] GET / (curl/7.27.0).
     [Sun Sep  2 23:27:04 2012] [debug] 200 OK (0.012039s, 83.063/s).
     ...
   #   push to heroku..
    mjp@uberwald:~/src/heroku/perl-heroku$ git status
     # Not currently on any branch.
     # Changes not staged for commit:
     #   (use "git add <file>..." to update what will be committed)
     #   (use "git checkout -- <file>..." to discard changes in working directory)
     #
     #	modified:   Makefile.PL
     #	modified:   Perloku
     #	modified:   carton.lock
     #	modified:   cpanfile
    
    mjp@uberwald:~/src/heroku/perl-heroku$ cat Procfile
     web: ./myapp.pl daemon --listen http://*:$PORT
    
    mjp@uberwald:~/src/heroku/perl-heroku$ git add Procfile
    mjp@uberwald:~/src/heroku/perl-heroku$ git status
     # Not currently on any branch.
     # Changes to be committed:
     #   (use "git reset HEAD <file>..." to unstage)
     #
     #	new file:   Procfile
     #
     # Changes not staged for commit:
     #   (use "git add <file>..." to update what will be committed)
     #   (use "git checkout -- <file>..." to discard changes in working directory)
     #
     #	modified:   Makefile.PL
     #	modified:   Perloku
     #	modified:   carton.lock
     #	modified:   cpanfile
    mjp@uberwald:~/src/heroku/perl-heroku$ git checkout master
     error: Your local changes to the following files would be overwritten by checkout:
     	carton.lock
     	cpanfile
     Please, commit your changes or stash them before you can switch branches.
     Aborting
    mjp@uberwald:~/src/heroku/perl-heroku$ git commit -m "setup carton" .
     [detached HEAD 978f428] setup carton
      5 files changed, 396 insertions(+), 4 deletions(-)
      create mode 100644 Procfile
    mjp@uberwald:~/src/heroku/perl-heroku$ git status
     # Not currently on any branch.
     # Untracked files:
     #   (use "git add <file>..." to include in what will be committed)
     #
     #	.carton/
     #	Makefile.PL~
     #	Perloku~
     #	Procfile~
     #	cpanfile~
     #	local/
     nothing added to commit but untracked files present (use "git add" to track)
    mjp@uberwald:~/src/heroku/perl-heroku$ git checkout master
     Warning: you are leaving 2 commits behind, not connected to
     any of your branches:
     
       978f428 setup carton
       ec561a9 add Plack and Starman
     
     If you want to keep them by creating a new branch, this may be a good time
     to do so with:
     
      git branch new_branch_name 978f4287d7f30509f76ea27bf2ef07494ddf84c7
     
     Switched to branch 'master'
    mjp@uberwald:~/src/heroku/perl-heroku$ git branch heroku_deps 978f4287d7f30509f76ea27bf2ef07494ddf84c7
    mjp@uberwald:~/src/heroku/perl-heroku$ git checkout heroku_deps
     Switched to branch 'heroku_deps'
    mjp@uberwald:~/src/heroku/perl-heroku$ git checkout master
     Switched to branch 'master'
    mjp@uberwald:~/src/heroku/perl-heroku$ ls cpanfile
     ls: cannot access cpanfile: No such file or directory
    mjp@uberwald:~/src/heroku/perl-heroku$ git status
     # On branch master
     ...
     nothing added to commit but untracked files present (use "git add" to track)
    mjp@uberwald:~/src/heroku/perl-heroku$ git merge heroku_deps
     Updating dabf5d9..978f428
     Fast-forward
      Makefile.PL |   11 +-
      Perloku     |   24 +-
      Procfile    |    1 +
      carton.lock | 3511 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
      cpanfile    |    3 +
      5 files changed, 3546 insertions(+), 4 deletions(-)
      create mode 100644 Procfile
      create mode 100644 carton.lock
      create mode 100644 cpanfile
    mjp@uberwald:~/src/heroku/perl-heroku$ ls cpanfile
     cpanfile
    # push to github first
    mjp@uberwald:~/src/heroku/perl-heroku$ git push -u origin master
     Username for 'https://github.com': phelanm
     Password for 'https://phelanm@github.com': ***
     
     Counting objects: 14, done.
     Delta compression using up to 2 threads.
     Compressing objects: 100% (10/10), done.
     Writing objects: 100% (11/11), 12.32 KiB, done.
     Total 11 (delta 2), reused 0 (delta 0)
     To https://github.com/phelanm/perl-heroku.git
        dabf5d9..978f428  master -> master
     Branch master set up to track remote branch master from origin.
    # now heroku
    mjp@uberwald:~/src/heroku/perl-heroku$ git push heroku master
     Counting objects: 20, done.
     Delta compression using up to 2 threads.
     Compressing objects: 100% (17/17), done.
     Writing objects: 100% (20/20), 13.10 KiB, done.
     Total 20 (delta 3), reused 0 (delta 0)
     
     -----> Heroku receiving push
     -----> Fetching custom buildpack... cloning with git...done
      !     Heroku push rejected, no Cedar-supported app detected
     
     To git@heroku.com:murmuring-basin-9623.git
      ! [remote rejected] master -> master (pre-receive hook declined)
     error: failed to push some refs to 'git@heroku.com:murmuring-basin-9623.git'
    # alter Perloku and myapp.pl
     #originally:
      cat Perloku
       #!/usr/bin/env perl
       use Mojolicious::Lite;
       
       get '/' => sub {
         my $self = shift;
         $self->render('index');
       };
       
       app->start;
       __DATA__
       
       @@ index.html.ep
       % layout 'default';
       % title 'Welcome';
       Welcome to the Mojolicious real-time web framework!
       
       @@ layouts/default.html.ep
       <!DOCTYPE html>
       <html>
         <head><title><%= title %></title></head>
         <body><%= content %></body>
       </html>
      
      
      cat ~/src/heroku/perl-heroku/myapp.pl
       #!/usr/bin/env perl
       use Mojolicious::Lite;
       
       get '/' => {text => 'Hello phelanm Mojo!'};
       
       app->start;
     #changed version:
      cat ~/src/heroku/perl-heroku/Perloku
       #!/bin/sh
       ./myapp.pl daemon -l http://*:$PORT -m production
      cat ~/src/heroku/perl-heroku/myapp.pl
       #!/usr/bin/env perl
       use Mojolicious::Lite;
       
       get '/' => sub {
         my $self = shift;
         $self->render('index');
       };
       
       app->start;
       __DATA__
       
       @@ index.html.ep
       % layout 'default';
       % title 'Welcome';
       Welcome to the Mojolicious real-time web framework!
       
       @@ layouts/default.html.ep
       <!DOCTYPE html>
       <html>
         <head><title><%= title %></title></head>
         <body><%= content %></body>
       </html>
    # run locally
     mjp@uberwald:~/src/heroku/perl-heroku$ carton install
      Installing modules using cpanfile
      You have Plack (1.0003)
      You have Starman (0.3001)
      You have Mojolicious (3.36)
      Complete! Modules were installed into local
     
     mjp@uberwald:~/src/heroku/perl-heroku$ carton exec -Ilib -- starman -p 8080 myapp.pl 
      2012/09/03-00:13:06 Starman::Server (type Net::Server::PreFork) starting! pid(7386)
      Resolved [*]:8080 to [0.0.0.0]:8080, IPv4
      Binding to TCP port 8080 on host 0.0.0.0 with IPv4
      Setting gid to "1000 1000 20 24 25 29 30 44 46 100 102 104 109 1000"
      ...
     
      mjp@uberwald:~/notes$ curl "http://localhost:8080"
       <!DOCTYPE html>
       <html>
         <head><title>mphelan Welcome</title></head>
         <body>Welcome to the Mojolicious real-time web framework!
       </body>
       </html>
     
      ...
      [Mon Sep  3 00:13:15 2012] [debug] Your secret passphrase needs to be changed!!!
      [Mon Sep  3 00:13:15 2012] [debug] GET / (curl/7.27.0).
      [Mon Sep  3 00:13:15 2012] [debug] Routing to a callback.
      [Mon Sep  3 00:13:15 2012] [debug] Rendering template "index.html.ep" from DATA section.
      [Mon Sep  3 00:13:15 2012] [debug] Rendering template "layouts/default.html.ep" from DATA section.
      [Mon Sep  3 00:13:15 2012] [debug] 200 OK (0.007699s, 129.887/s).
      ...
 
    # checkin to github
     mjp@uberwald:~/src/heroku/perl-heroku$ git add Perloku myapp.pl
     mjp@uberwald:~/src/heroku/perl-heroku$ git status
      # On branch master
      # Changes to be committed:
      #   (use "git reset HEAD <file>..." to unstage)
      #
      #	modified:   Perloku
      #	modified:   myapp.pl
     mjp@uberwald:~/src/heroku/perl-heroku$ git commit -m "alter to work with heroku" .
      [master 17ce71b] alter to work with heroku
       2 files changed, 19 insertions(+), 23 deletions(-)
     mjp@uberwald:~/src/heroku/perl-heroku$ git push -u origin master
      Username for 'https://github.com': phelanm
      Password for 'https://phelanm@github.com': ***
      
      Counting objects: 7, done.
      Delta compression using up to 2 threads.
      Compressing objects: 100% (4/4), done.
      Writing objects: 100% (4/4), 393 bytes, done.
      Total 4 (delta 2), reused 0 (delta 0)
      To https://github.com/phelanm/perl-heroku.git
         978f428..17ce71b  master -> master
      Branch master set up to track remote branch master from origin.
    # try to push to heroku
     mjp@uberwald:~/src/heroku/perl-heroku$ git push heroku master
      Counting objects: 23, done.
      Delta compression using up to 2 threads.
      Compressing objects: 100% (20/20), done.
      Writing objects: 100% (23/23), 13.35 KiB, done.
      Total 23 (delta 5), reused 0 (delta 0)
      
      -----> Heroku receiving push
      -----> Fetching custom buildpack... cloning with git...done
       !     Heroku push rejected, no Cedar-supported app detected
      
      To git@heroku.com:murmuring-basin-9623.git
       ! [remote rejected] master -> master (pre-receive hook declined)
      error: failed to push some refs to 'git@heroku.com:murmuring-basin-9623.git'
     mjp@uberwald:~/src/heroku/perl-heroku$ heroku create -s cedar --buildpack http://github.com/phelanm/perl-heroku.git
      Creating quiet-woodland-8393... done, stack is cedar
      BUILDPACK_URL=http://github.com/phelanm/perl-heroku.git
      http://quiet-woodland-8393.herokuapp.com/ | git@heroku.com:quiet-woodland-8393.git
     mjp@uberwald:~/src/heroku/perl-heroku$ curl "http://quiet-woodland-8393.herokuapp.com/"
      <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
          <html>
          <head>
              <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
              <title>Heroku | Welcome to your new app!</title>
      ...
     mjp@uberwald:~/src/heroku/perl-heroku$ git push heroku master
      Counting objects: 23, done.
      Delta compression using up to 2 threads.
      Compressing objects: 100% (20/20), done.
      Writing objects: 100% (23/23), 13.35 KiB, done.
      Total 23 (delta 5), reused 0 (delta 0)
      
      -----> Heroku receiving push
      -----> Fetching custom buildpack... cloning with git...done
       !     Heroku push rejected, no Cedar-supported app detected
      
      To git@heroku.com:murmuring-basin-9623.git
       ! [remote rejected] master -> master (pre-receive hook declined)
      error: failed to push some refs to 'git@heroku.com:murmuring-basin-9623.git'
     # update ~/src/heroku/perl-heroku/Makefile.PL
       NAME         => 'myapp.pl',
       AUTHOR       => 'mark phelan <phelanm@gmail.com>',
       EXE_FILES    => ['myapp.pl'],
      git status
      git add Makefile.PL
      git commit -m "alter for heroku again" .
     # push to github
      mjp@uberwald:~/src/heroku/perl-heroku$ git push -u origin master
       Username for 'https://github.com': phelanm
       Password for 'https://phelanm@github.com': ***
       Counting objects: 5, done.
       Delta compression using up to 2 threads.
       Compressing objects: 100% (3/3), done.
       Writing objects: 100% (3/3), 332 bytes, done.
       Total 3 (delta 2), reused 0 (delta 0)
       To https://github.com/phelanm/perl-heroku.git
          17ce71b..b359dfb  master -> master
       Branch master set up to track remote branch master from origin.
     # try to push to heroku
      mjp@uberwald:~/src/heroku/perl-heroku$ git push heroku master
       Counting objects: 26, done.
       Delta compression using up to 2 threads.
       Compressing objects: 100% (23/23), done.
       Writing objects: 100% (26/26), 13.61 KiB, done.
       Total 26 (delta 7), reused 0 (delta 0)
       
       -----> Heroku receiving push
       -----> Fetching custom buildpack... cloning with git...done
        !     Heroku push rejected, no Cedar-supported app detected
       
       To git@heroku.com:murmuring-basin-9623.git
        ! [remote rejected] master -> master (pre-receive hook declined)
       error: failed to push some refs to 'git@heroku.com:murmuring-basin-9623.git'
      mjp@uberwald:~/src/heroku/perl-heroku$ heroku create -s cedar --buildpack http://github.com/phelanm/perl-heroku.git
       Creating calm-brushlands-2877... done, stack is cedar
       BUILDPACK_URL=http://github.com/phelanm/perl-heroku.git
       http://calm-brushlands-2877.herokuapp.com/ | git@heroku.com:calm-brushlands-2877.git
      
      mjp@uberwald:~/src/heroku/perl-heroku$ heroku create -s cedar --buildpack http://github.com/phelanm/perl-heroku.git
       Creating calm-brushlands-2877... done, stack is cedar
       BUILDPACK_URL=http://github.com/phelanm/perl-heroku.git
       http://calm-brushlands-2877.herokuapp.com/ | git@heroku.com:calm-brushlands-2877.git
      mjp@uberwald:~/src/heroku/perl-heroku$  git push heroku master
       Counting objects: 26, done.
       Delta compression using up to 2 threads.
       Compressing objects: 100% (23/23), done.
       Writing objects: 100% (26/26), 13.61 KiB, done.
       Total 26 (delta 7), reused 0 (delta 0)
       
       -----> Heroku receiving push
       -----> Fetching custom buildpack... cloning with git...done
        !     Heroku push rejected, no Cedar-supported app detected
       
       To git@heroku.com:murmuring-basin-9623.git
        ! [remote rejected] master -> master (pre-receive hook declined)
       error: failed to push some refs to 'git@heroku.com:murmuring-basin-9623.git'
     
     # try to rip off working one..
      mjp@uberwald:~/src/heroku$ git clone  http://github.com/judofyr/perloku.git
     
      mjp@uberwald:~/src/heroku/perl-heroku$ cp -R ../perloku/support/ .
      mjp@uberwald:~/src/heroku/perl-heroku$ cp -R ../perloku/bin/ .
      mjp@uberwald:~/src/heroku/perl-heroku$ git add bin support
      mjp@uberwald:~/src/heroku/perl-heroku$ git commit -m "add bin/ support/ from perloku" .
       [master 6037dbd] add bin/ support/ from perloku
        4 files changed, 83 insertions(+)
        create mode 100755 bin/compile
        create mode 100755 bin/detect
        create mode 100755 bin/release
        create mode 100755 support/build_perl
      mjp@uberwald:~/src/heroku/perl-heroku$ git push -u origin master
       Username for 'https://github.com': phelanm
       Password for 'https://phelanm@github.com': ***
       
       Counting objects: 9, done.
       Delta compression using up to 2 threads.
       Compressing objects: 100% (7/7), done.
       Writing objects: 100% (8/8), 1.44 KiB, done.
       Total 8 (delta 1), reused 0 (delta 0)
       To https://github.com/phelanm/perl-heroku.git
          b359dfb..6037dbd  master -> master
       Branch master set up to track remote branch master from origin.
      mjp@uberwald:~/src/heroku/perl-heroku$   git push heroku master
       Counting objects: 34, done.
       Delta compression using up to 2 threads.
       Compressing objects: 100% (30/30), done.
       Writing objects: 100% (34/34), 15.00 KiB, done.
       Total 34 (delta 8), reused 0 (delta 0)
       
       -----> Heroku receiving push
       -----> Fetching custom buildpack... cloning with git...done
       -----> Perloku app detected
       -----> Vendoring Perl
              Using Perl 5.14.2
       -----> Installing dependencies
              --> Working on /tmp/build_3ta69zgbeo8w0
              Configuring /tmp/build_3ta69zgbeo8w0 ... OK
              ==> Found dependencies: Mojolicious
              --> Working on Mojolicious
              Fetching http://search.cpan.org/CPAN/authors/id/S/SR/SRI/Mojolicious-3.36.tar.gz ... OK
              Configuring Mojolicious-3.36 ... OK
              Building Mojolicious-3.36 ... OK
              Successfully installed Mojolicious-3.36
              <== Installed dependencies for /tmp/build_3ta69zgbeo8w0. Finishing.
              1 distribution installed
              Dependencies installed
       -----> Discovering process types
              Procfile declares types -> web
       -----> Compiled slug size is 12.4MB
       -----> Launching... done, v4
              http://murmuring-basin-9623.herokuapp.com deployed to Heroku
       
       To git@heroku.com:murmuring-basin-9623.git
        * [new branch]      master -> master
      mjp@uberwald:~/src/heroku/perl-heroku$ curl "http://murmuring-basin-9623.herokuapp.com"
       <!DOCTYPE html>
       <html>
         <head><title>mphelan Welcome</title></head>
         <body>Welcome to the Mojolicious real-time web framework!
       </body>
       </html>