CherryPy - Panduan Cepat

CherryPy adalah kerangka kerja web Python yang menyediakan antarmuka ramah ke protokol HTTP untuk pengembang Python. Ini juga disebut perpustakaan aplikasi web.

CherryPy menggunakan kekuatan Python sebagai bahasa dinamis untuk memodelkan dan mengikat protokol HTTP ke dalam API. Ini adalah salah satu kerangka kerja web tertua untuk Python, yang menyediakan antarmuka bersih dan platform yang andal.

Sejarah CherryPy

Remi Delon merilis versi pertama CherryPy pada akhir Juni 2002. Ini adalah titik awal dari pustaka web Python yang sukses. Remi adalah seorang peretas Prancis yang telah mempercayai Python sebagai salah satu alternatif terbesar untuk pengembangan aplikasi web.

Proyek yang dikembangkan Remi menarik sejumlah developer yang tertarik dengan pendekatan tersebut. Pendekatan tersebut mencakup fitur-fitur berikut -

  • CherryPy dekat dengan pola model-view-controller.

  • Kelas CherryPy harus diproses dan dikompilasi oleh mesin CherryPy untuk menghasilkan modul Python mandiri yang menyematkan aplikasi lengkap dan juga server web bawaannya sendiri.

  • CherryPy dapat memetakan URL dan string kuerinya ke dalam panggilan metode Python, misalnya -

http://somehost.net/echo?message=hello would map to echo(message='hello')

Selama dua tahun pengembangan proyek CherryPy, didukung oleh komunitas dan Remi merilis beberapa versi perbaikan.

Pada bulan Juni 2004, sebuah diskusi dimulai tentang masa depan proyek dan apakah harus dilanjutkan dengan arsitektur yang sama. Brainstorming dan diskusi oleh beberapa pelanggan tetap proyek kemudian mengarah pada konsep mesin dan filter penerbitan objek, yang segera menjadi bagian inti dari CherryPy2. Kemudian, pada bulan Oktober 2004, versi pertama CherryPy 2 alpha dirilis sebagai bukti konsep ide inti ini. CherryPy 2.0 benar-benar sukses; Namun, disadari bahwa desainnya masih dapat ditingkatkan, dan perlu refactoring.

Setelah diskusi berdasarkan masukan, CherryPy API dimodifikasi lebih lanjut untuk meningkatkan keanggunannya, yang mengarah ke rilis CherryPy 2.1.0 pada bulan Oktober 2005. Setelah berbagai perubahan, tim merilis CherryPy 2.2.0 pada bulan April 2006.

Kekuatan CherryPy

Fitur CherryPy berikut dianggap sebagai kekuatannya -

Kesederhanaan

Mengembangkan proyek di CherryPy adalah tugas sederhana dengan beberapa baris kode yang dikembangkan sesuai dengan konvensi dan lekukan Python.

CherryPy juga sangat modular. Komponen utama dikelola dengan baik dengan konsep logika yang benar dan kelas induk dapat diperluas ke kelas anak.

Kekuasaan

CherryPy memanfaatkan semua kekuatan Python. Ini juga menyediakan alat dan plugin, yang merupakan titik ekstensi kuat yang diperlukan untuk mengembangkan aplikasi kelas dunia.

Sumber terbuka

CherryPy adalah Kerangka Web Python sumber terbuka (dilisensikan di bawah lisensi BSD sumber terbuka), yang berarti kerangka kerja ini dapat digunakan secara komersial dengan biaya NOL.

Bantuan Komunitas

Ini memiliki komunitas yang setia yang memberikan dukungan lengkap dengan berbagai jenis pertanyaan dan jawaban. Komunitas berusaha memberikan bantuan penuh kepada para pengembang mulai dari tingkat pemula hingga mahir.

Penyebaran

Ada cara hemat biaya untuk menerapkan aplikasi. CherryPy menyertakan server HTTP-nya sendiri yang siap produksi untuk menghosting aplikasi Anda. CherryPy juga dapat digunakan pada gateway yang sesuai dengan WSGI.

CherryPy hadir dalam paket seperti kebanyakan proyek sumber terbuka, yang dapat diunduh dan diinstal dengan berbagai cara yang disebutkan sebagai berikut -

  • Menggunakan Tarball
  • Menggunakan easy_install
  • Menggunakan Subversion

Persyaratan

Persyaratan dasar untuk pemasangan kerangka CherryPy meliputi -

  • Python dengan versi 2.4 atau lebih tinggi
  • CherryPy 3.0.0 Memperbarui

Menginstal modul Python dianggap sebagai proses yang mudah. Penginstalan mencakup penggunaan perintah berikut.

python setup.py build
python setup.py install

Paket Python disimpan di direktori default berikut -

  • Di UNIX atau Linux,
/usr/local/lib/python2.4/site-packages
or
/usr/lib/python2.4/site-packages
  • Di Microsoft Windows,
C:\Python or C:\Python2x
  • Di Mac OS,
Python:Lib:site-package

Instalasi menggunakan Tarball

Tarball adalah arsip file atau direktori terkompresi. Framework CherryPy menyediakan Tarball untuk setiap rilisnya (alfa, beta, dan stabil).

Ini berisi kode sumber lengkap dari perpustakaan. Namanya berasal dari utilitas yang digunakan di UNIX dan sistem operasi lain.

Berikut adalah langkah-langkah yang harus diikuti untuk instalasi CherryPy menggunakan bola tar -

Step 1 - Unduh versi sesuai kebutuhan pengguna dari http://download.cherrypy.org/

Step 2- Cari direktori tempat Tarball telah diunduh dan buka kompresnya. Untuk sistem operasi Linux, ketik perintah berikut -

tar zxvf cherrypy-x.y.z.tgz

Untuk Microsoft Windows, pengguna dapat menggunakan utilitas seperti 7-Zip atau Winzip untuk membuka kompresi arsip melalui antarmuka grafis.

Step 3 - Pindah ke direktori yang baru dibuat dan gunakan perintah berikut untuk membuat CherryPy -

python setup.py build

Untuk penginstalan global, perintah berikut harus digunakan -

python setup.py install

Instalasi menggunakan easy_install

Python Enterprise Application Kit (PEAK) menyediakan modul python bernama Easy Install. Ini memfasilitasi penyebaran paket Python. Modul ini menyederhanakan prosedur mengunduh, membangun, dan menerapkan aplikasi dan produk Python.

Instalasi Mudah harus diinstal di sistem sebelum menginstal CherryPy.

Step 1 - Unduh modul ez_setup.py dari http://peak.telecommunity.com dan menjalankannya menggunakan hak administratif di komputer: python ez_setup.py.

Step 2 - Perintah berikut digunakan untuk menginstal Easy Install.

easy_install product_name

Step 3- easy_install akan mencari Python Package Index (PyPI) untuk menemukan produk yang diberikan. PyPI adalah tempat penyimpanan informasi terpusat untuk semua produk Python.

Gunakan perintah berikut untuk menerapkan versi CherryPy terbaru yang tersedia -

easy_install cherrypy

Step 4 - easy_install kemudian akan mengunduh CherryPy, membangun, dan menginstalnya secara global ke lingkungan Python Anda.

Instalasi menggunakan Subversion

Instalasi CherryPy menggunakan Subversion direkomendasikan dalam situasi berikut -

  • Ada fitur atau bug telah diperbaiki dan hanya tersedia dalam kode yang sedang dikembangkan.

  • Saat pengembang mengerjakan CherryPy itu sendiri.

  • Ketika pengguna membutuhkan cabang dari cabang utama di repositori kontrol versi.

  • Untuk perbaikan bug dari rilis sebelumnya.

Prinsip dasar subversi adalah mendaftarkan repositori dan melacak setiap versi, yang menyertakan serangkaian perubahan di dalamnya.

Ikuti langkah-langkah ini untuk memahami instalasi CherryPy menggunakan Subversion−

Step 1 - Untuk menggunakan versi terbaru dari proyek ini, Anda perlu memeriksa folder trunk yang ada di repositori Subversion.

Step 2 - Masukkan perintah berikut dari shell−

svn co http://svn.cherrypy.org/trunk cherrypy

Step 3 - Sekarang, buat direktori CherryPy dan unduh kode sumber lengkap ke dalamnya.

Menguji Instalasi

Perlu diverifikasi apakah aplikasi tersebut telah diinstal dengan benar di sistem atau tidak dengan cara yang sama seperti yang kita lakukan untuk aplikasi seperti Java.

Anda dapat memilih salah satu dari tiga metode yang disebutkan di bab sebelumnya untuk menginstal dan menerapkan CherryPy di ​​lingkungan Anda. CherryPy harus dapat mengimpor dari shell Python sebagai berikut -

import cherrypy

cherrypy.__version__
'3.0.0'

Jika CherryPy tidak diinstal secara global ke lingkungan Python sistem lokal, maka Anda perlu mengatur variabel lingkungan PYTHONPATH, jika tidak maka akan menampilkan kesalahan dengan cara berikut -

import cherrypy

Traceback (most recent call last):
File "<stdin>", line 1, in ?
ImportError: No module named cherrypy

Ada beberapa kata kunci penting yang perlu didefinisikan untuk memahami cara kerja CherryPy. Kata kunci dan definisinya adalah sebagai berikut -

S.No Kata Kunci & Definisi
1.

Web Server

Ini adalah antarmuka yang berurusan dengan protokol HTTP. Tujuannya adalah untuk mengubah permintaan HTTP ke server aplikasi sehingga mendapat tanggapan.

2.

Application

Ini adalah perangkat lunak yang mengumpulkan informasi.

3.

Application server

Ini adalah komponen yang menampung satu atau lebih aplikasi

4.

Web application server

Ini adalah kombinasi dari server web dan server aplikasi.

Contoh

Contoh berikut menunjukkan kode sampel CherryPy -

import cherrypy

class demoExample:
   def index(self):
   return "Hello World!!!"
   index.exposed = True
cherrypy.quickstart(demoExample())

Mari kita sekarang memahami cara kerja kode -

  • Paket bernama CherryPy selalu diimpor di kelas yang ditentukan untuk memastikan berfungsi dengan baik.

  • Dalam contoh di atas, fungsi bernama index mengembalikan parameter “Hello World !!!”.

  • Baris terakhir memulai server web dan memanggil kelas yang ditentukan (di sini, demoExample) dan mengembalikan nilai yang disebutkan dalam indeks fungsi default.

Kode contoh mengembalikan keluaran berikut -

CherryPy hadir dengan server web (HTTP) sendiri. Itulah mengapa CherryPy berdiri sendiri dan memungkinkan pengguna untuk menjalankan aplikasi CherryPy dalam beberapa menit setelah mendapatkan perpustakaan.

Itu web server bertindak sebagai pintu gerbang ke aplikasi dengan bantuan yang semua permintaan dan tanggapan disimpan di jalurnya.

Untuk memulai server web, pengguna harus melakukan panggilan berikut -

cherryPy.server.quickstart()

Itu internal engine of CherryPy bertanggung jawab atas aktivitas berikut -

  • Pembuatan dan pengelolaan objek permintaan dan respons.
  • Mengontrol dan mengelola proses CherryPy.

CherryPy - Konfigurasi

Kerangka kerja ini dilengkapi dengan sistem konfigurasinya sendiri yang memungkinkan Anda untuk membuat parameter server HTTP. Pengaturan untuk konfigurasi dapat disimpan baik dalam file teks dengan sintaks yang dekat dengan format INI atau sebagai kamus Python lengkap.

Untuk mengonfigurasi instance server CherryPy, pengembang perlu menggunakan bagian global dari pengaturan.

global_conf = {
   'global': {
      'server.socket_host': 'localhost',
      'server.socket_port': 8080,
   },
}

application_conf = {
   '/style.css': {
      'tools.staticfile.on': True,
      'tools.staticfile.filename': os.path.join(_curdir, 'style.css'),
   }
}

This could be represented in a file like this:
[global]
server.socket_host = "localhost"
server.socket_port = 8080
[/style.css]
tools.staticfile.on = True
tools.staticfile.filename = "/full/path/to.style.css"

Kepatuhan HTTP

CherryPy telah berkembang secara perlahan tetapi itu termasuk kompilasi spesifikasi HTTP dengan dukungan HTTP / 1.0 yang kemudian ditransfer dengan dukungan HTTP / 1.1.

CherryPy dikatakan sesuai secara kondisional dengan HTTP / 1.1 karena ia menerapkan semua tingkat keharusan dan yang diperlukan tetapi tidak semua tingkat spesifikasi harus. Oleh karena itu, CherryPy mendukung fitur HTTP / 1.1 berikut -

  • Jika klien mengklaim mendukung HTTP / 1.1, ia harus mengirimkan bidang header dalam setiap permintaan yang dibuat dengan versi protokol yang ditentukan. Jika tidak dilakukan, CherryPy akan segera menghentikan pemrosesan permintaan.

  • CherryPy menghasilkan bidang header Tanggal yang digunakan di semua konfigurasi.

  • CherryPy dapat menangani kode status respons (100) dengan dukungan klien.

  • Server HTTP bawaan CherryPy mendukung koneksi persisten yang merupakan default di HTTP / 1.1, melalui penggunaan header Connection: Keep-Alive.

  • CherryPy menangani permintaan dan tanggapan yang dipotong dengan benar.

  • CherryPy mendukung permintaan dalam dua cara berbeda - header If-Modified-Because dan If-Unmodified-Because dan mengirimkan tanggapan sesuai permintaan yang sesuai.

  • CherryPy mengizinkan metode HTTP apa pun.

  • CherryPy menangani kombinasi versi HTTP antara klien dan set pengaturan untuk server.

Server Aplikasi Multithreaded

CherryPy dirancang berdasarkan konsep multithreading. Setiap kali pengembang mendapatkan atau menetapkan nilai ke dalam namespace CherryPy, hal itu dilakukan di lingkungan multi-utas.

Baik cherrypy.request dan cherrypy.response adalah wadah data utas, yang menyiratkan bahwa aplikasi Anda memanggilnya secara independen dengan mengetahui permintaan mana yang diproksikan melaluinya pada waktu proses.

Server aplikasi yang menggunakan pola ulir tidak terlalu dianggap karena penggunaan utas dipandang meningkatkan kemungkinan masalah karena persyaratan sinkronisasi.

Alternatif lain termasuk -

Pola Multi-proses

Setiap permintaan ditangani oleh proses Python-nya sendiri. Di sini, kinerja dan stabilitas server dapat dianggap lebih baik.

Pola Asinkron

Di sini, menerima koneksi baru dan mengirim data kembali ke klien dilakukan secara asinkron dari proses permintaan. Teknik ini dikenal dengan efisiensinya.

Pengiriman URL

Komunitas CherryPy ingin menjadi lebih fleksibel dan solusi lain untuk operator akan dihargai. CherryPy 3 menyediakan dispatcher built-in lainnya dan menawarkan cara sederhana untuk menulis dan menggunakan dispatcher Anda sendiri.

  • Aplikasi yang digunakan untuk mengembangkan metode HTTP. (DAPATKAN, POSTING, PUT, dll.)
  • Yang mendefinisikan rute di URL - Rute Dispatcher

Penerima Metode HTTP

Dalam beberapa aplikasi, URI tidak bergantung pada tindakan, yang akan dilakukan oleh server pada sumber daya.

Sebagai contoh,http://xyz.com/album/delete/10

URI berisi operasi yang ingin dijalankan klien.

Secara default, operator CherryPy akan memetakan dengan cara berikut -

album.delete(12)

Dispatcher yang disebutkan di atas disebutkan dengan benar, tetapi dapat dibuat independen dengan cara berikut -

http://xyz.com/album/10

Pengguna mungkin bertanya-tanya bagaimana server mengirimkan halaman yang tepat. Informasi ini dibawa oleh permintaan HTTP itu sendiri. Ketika ada permintaan dari klien ke server, CherryPy terlihat sebagai penangan setelan terbaik, penangan adalah representasi sumber daya yang ditargetkan oleh URI.

DELETE /album/12 HTTP/1.1

Rute Dispatcher

Berikut adalah daftar parameter untuk metode yang diperlukan dalam pengiriman -

  • Parameter name adalah nama unik untuk rute yang akan dihubungkan.

  • Rute adalah pola untuk mencocokkan URI.

  • Pengontrol adalah instance yang berisi penangan halaman.

  • Menggunakan Routes dispatcher menghubungkan pola yang cocok dengan URI dan mengaitkan penangan halaman tertentu.

Contoh

Mari kita ambil contoh untuk memahami cara kerjanya -

import random
import string
import cherrypy

class StringMaker(object):
   @cherrypy.expose
   def index(self):
      return "Hello! How are you?"
   
   @cherrypy.expose
   def generate(self, length=9):
      return ''.join(random.sample(string.hexdigits, int(length)))
		
if __name__ == '__main__':
   cherrypy.quickstart(StringMaker ())

Ikuti langkah-langkah yang diberikan di bawah ini untuk mendapatkan output dari kode di atas -

Step 1 - Simpan file yang disebutkan di atas sebagai tutRoutes.py.

Step 2 - Kunjungi URL berikut -

http://localhost:8080/generate?length=10

Step 3 - Anda akan menerima output berikut -

Di dalam CherryPy, alat bawaan menawarkan satu antarmuka untuk memanggil pustaka CherryPy. Alat yang ditentukan di CherryPy dapat diimplementasikan dengan cara berikut -

  • Dari pengaturan konfigurasi
  • Sebagai dekorator Python atau melalui atribut _cp_config khusus dari penangan halaman
  • Sebagai callable Python yang dapat diterapkan dari dalam fungsi apa pun

Alat Otentikasi Dasar

Tujuan alat ini adalah menyediakan otentikasi dasar untuk aplikasi yang dirancang dalam aplikasi.

Argumen

Alat ini menggunakan argumen berikut -

Nama Default Deskripsi
dunia T / A String yang mendefinisikan nilai realm.
pengguna T / A Bentuk kamus - nama pengguna: kata sandi atau fungsi panggil Python yang mengembalikan kamus semacam itu.
mengenkripsi Tidak ada Python callable digunakan untuk mengenkripsi kata sandi yang dikembalikan oleh klien dan membandingkannya dengan kata sandi terenkripsi yang disediakan dalam kamus pengguna.

Contoh

Mari kita ambil contoh untuk memahami cara kerjanya -

import sha
import cherrypy

class Root:
@cherrypy.expose
def index(self):

return """
<html>
   <head></head>
   <body>
      <a href = "admin">Admin </a>
   </body>
</html>
""" 

class Admin:

@cherrypy.expose
def index(self):
return "This is a private area"

if __name__ == '__main__':
def get_users():
# 'test': 'test'
return {'test': 'b110ba61c4c0873d3101e10871082fbbfd3'}
def encrypt_pwd(token):

return sha.new(token).hexdigest()
   conf = {'/admin': {'tools.basic_auth.on': True,
      tools.basic_auth.realm': 'Website name',
      'tools.basic_auth.users': get_users,
      'tools.basic_auth.encrypt': encrypt_pwd}}
   root = Root()
root.admin = Admin()
cherrypy.quickstart(root, '/', config=conf)

Itu get_usersfunction mengembalikan kamus hard-code tetapi juga mengambil nilai dari database atau di mana pun. Admin kelas menyertakan fungsi ini yang menggunakan alat autentikasi bawaan CherryPy. Otentikasi mengenkripsi kata sandi dan ID pengguna.

Alat otentikasi dasar tidak terlalu aman, karena kata sandi dapat dikodekan dan diterjemahkan oleh penyusup.

Alat Caching

Tujuan alat ini adalah untuk menyediakan cache memori dari konten yang dihasilkan CherryPy.

Argumen

Alat ini menggunakan argumen berikut -

Nama Default Deskripsi
invalid_methods ("POSTING", "PUT", "HAPUS") Tupel dari string metode HTTP tidak akan di-cache. Metode ini juga akan membatalkan (menghapus) semua salinan sumber daya yang di-cache.
cache_Class MemoryCache Objek kelas yang akan digunakan untuk cache

Alat Decoding

Tujuan alat ini adalah untuk memecahkan kode parameter permintaan yang masuk.

Argumen

Alat ini menggunakan argumen berikut -

Nama Default Deskripsi
pengkodean Tidak ada Ini mencari header tipe konten
Pengodean_ default "UTF-8" Pengkodean default untuk digunakan jika tidak ada yang disediakan atau ditemukan.

Contoh

Mari kita ambil contoh untuk memahami cara kerjanya -

import cherrypy
from cherrypy import tools

class Root:
@cherrypy.expose
def index(self):

return """ 
<html>
   <head></head>
   <body>
      <form action = "hello.html" method = "post">
         <input type = "text" name = "name" value = "" />
         <input type = ”submit” name = "submit"/>
      </form>
   </body>
</html>
"""

@cherrypy.expose
@tools.decode(encoding='ISO-88510-1')
def hello(self, name):
return "Hello %s" % (name, )
if __name__ == '__main__':
cherrypy.quickstart(Root(), '/')

Kode di atas mengambil string dari pengguna dan akan mengarahkan pengguna ke halaman "hello.html" di mana ia akan ditampilkan sebagai "Halo" dengan nama yang diberikan.

Output dari kode di atas adalah sebagai berikut -

hello.html

Aplikasi full stack menyediakan fasilitas untuk membuat aplikasi baru melalui beberapa perintah atau eksekusi file.

Pertimbangkan aplikasi Python seperti kerangka web2py; seluruh proyek / aplikasi dibuat dalam kerangka MVC. Demikian juga, CherryPy memungkinkan pengguna untuk mengatur dan mengkonfigurasi tata letak kode sesuai kebutuhan mereka.

Pada bab ini, kita akan mempelajari secara detail cara membuat aplikasi CherryPy dan menjalankannya.

Berkas sistem

Sistem file aplikasi ditunjukkan pada tangkapan layar berikut -

Berikut adalah uraian singkat tentang berbagai file yang kami miliki di sistem file -

  • config.py- Setiap aplikasi membutuhkan file konfigurasi dan cara untuk memuatnya. Fungsionalitas ini dapat didefinisikan di config.py.

  • controllers.py- MVC adalah pola desain populer yang diikuti oleh pengguna. Controllers.py adalah tempat semua objek diimplementasikan yang akan dipasang di cherrypy.tree .

  • models.py - File ini berinteraksi dengan database secara langsung untuk beberapa layanan atau untuk menyimpan data persisten.

  • server.py - File ini berinteraksi dengan server web siap produksi yang bekerja dengan baik dengan proxy load balancing.

  • Static - Ini mencakup semua file CSS dan gambar.

  • Views - Ini mencakup semua file template untuk aplikasi tertentu.

Contoh

Mari kita pelajari secara detail langkah-langkah membuat aplikasi CherryPy.

Step 1 - Buat aplikasi yang harus berisi aplikasi tersebut.

Step 2- Di dalam direktori, buat paket python yang sesuai dengan proyek. Buat direktori gedit dan sertakan file _init_.py di dalamnya.

Step 3 - Di dalam paket, sertakan file controllers.py dengan konten berikut -

#!/usr/bin/env python

import cherrypy

class Root(object):

   def __init__(self, data):
      self.data = data

   @cherrypy.expose
   def index(self):
      return 'Hi! Welcome to your application'

def main(filename):
   data = {} # will be replaced with proper functionality later

   # configuration file
   cherrypy.config.update({
      'tools.encode.on': True, 'tools.encode.encoding': 'utf-8',
      'tools.decode.on': True,
      'tools.trailing_slash.on': True,
      'tools.staticdir.root': os.path.abspath(os.path.dirname(__file__)),
   })

   cherrypy.quickstart(Root(data), '/', {
      '/media': {
         'tools.staticdir.on': True,
         'tools.staticdir.dir': 'static'
      }
   })
	
if __name__ == '__main__':
main(sys.argv[1])

Step 4- Pertimbangkan aplikasi di mana pengguna memasukkan nilai melalui formulir. Mari sertakan dua bentuk - index.html dan submit.html dalam aplikasi.

Step 5 - Dalam kode di atas untuk pengontrol, kami punya index(), yang merupakan fungsi default dan memuat pertama kali jika pengontrol tertentu dipanggil.

Step 6 - Pelaksanaan index() metode dapat diubah dengan cara berikut -

@cherrypy.expose
   def index(self):
      tmpl = loader.load('index.html')
	 
      return tmpl.generate(title='Sample').render('html', doctype='html')

Step 7- Ini akan memuat index.html saat memulai aplikasi yang diberikan dan mengarahkannya ke aliran keluaran yang diberikan. File index.html adalah sebagai berikut -

index.html

<!DOCTYPE html >
<html>
   <head>
      <title>Sample</title>
   </head>
	
   <body class = "index">
      <div id = "header">
         <h1>Sample Application</h1>
      </div>
		
      <p>Welcome!</p>
		
      <div id = "footer">
         <hr>
      </div>
		
   </body>
	
</html>

Step 8 - Penting untuk menambahkan metode ke kelas Root di controller.py jika Anda ingin membuat formulir yang menerima nilai seperti nama dan judul.

@cherrypy.expose
   def submit(self, cancel = False, **value):
	
      if cherrypy.request.method == 'POST':
         if cancel:
            raise cherrypy.HTTPRedirect('/') # to cancel the action
         link = Link(**value)
         self.data[link.id] = link
         raise cherrypy.HTTPRedirect('/')
      tmp = loader.load('submit.html')
      streamValue = tmp.generate()
		
      return streamValue.render('html', doctype='html')

Step 9 - Kode yang akan dimasukkan dalam submit.html adalah sebagai berikut -

<!DOCTYPE html>
   <head>
      <title>Input the new link</title>
   </head>
	
   <body class = "submit">
      <div id = " header">
         <h1>Submit new link</h1>
      </div>
		
      <form action = "" method = "post">
         <table summary = "">
            <tr>
               <th><label for = " username">Your name:</label></th>
               <td><input type = " text" id = " username" name = " username" /></td>
            </tr>
				
            <tr>
               <th><label for = " url">Link URL:</label></th>
               <td><input type = " text" id=" url" name= " url" /></td>
            </tr>
				
            <tr>
               <th><label for = " title">Title:</label></th>
               <td><input type = " text" name = " title" /></td>
            </tr>
				
            <tr>
               <td></td>
               <td>
                  <input type = " submit" value = " Submit" />
                  <input type = " submit" name = " cancel" value = "Cancel" />
               </td>
            </tr>
				
         </table>
			
      </form>
      <div id = "footer">
      </div>
		
   </body>
	
</html>

Step 10 - Anda akan menerima output berikut -

Di sini, nama metode didefinisikan sebagai "POST". Selalu penting untuk memverifikasi silang metode yang ditentukan dalam file. Jika metode tersebut menyertakan metode "POST", nilainya harus diperiksa ulang dalam database di bidang yang sesuai.

Jika metode tersebut menyertakan metode "GET", nilai yang akan disimpan akan terlihat di URL.

Layanan web adalah sekumpulan komponen berbasis web yang membantu dalam pertukaran data antara aplikasi atau sistem yang juga mencakup protokol dan standar terbuka. Itu dapat diterbitkan, digunakan dan ditemukan di web.

Layanan web memiliki berbagai jenis seperti RWS (RESTfUL Web Service), WSDL, SOAP, dan banyak lagi.

REST - Transfer Negara Perwakilan

Jenis protokol akses jarak jauh, yang mentransfer status dari klien ke server yang dapat digunakan untuk memanipulasi status alih-alih memanggil prosedur jarak jauh.

  • Tidak menentukan pengkodean atau struktur tertentu dan cara mengembalikan pesan kesalahan yang berguna.

  • Menggunakan "verba" HTTP untuk melakukan operasi transfer status.

  • Sumber daya diidentifikasi secara unik menggunakan URL.

  • Ini bukan API melainkan lapisan transport API.

REST mempertahankan nomenklatur sumber daya di jaringan dan menyediakan mekanisme terpadu untuk melakukan operasi pada sumber daya ini. Setiap sumber daya diidentifikasi oleh setidaknya satu pengenal. Jika infrastruktur REST diimplementasikan dengan basis HTTP, maka pengenal ini disebut sebagaiUniform Resource Identifiers (URIs).

Berikut ini adalah dua subset umum dari set URI -

Subset Wujud sempurna Contoh
URL Uniform Resource Locator http://www.gmail.com/
PASU Uniform Resource Name urn: isbn: 0-201-71088-9 urn: uuid: 13e8cf26-2a25-11db-8693-000ae4ea7d46

Sebelum memahami implementasi arsitektur CherryPy, mari kita fokus pada arsitektur CherryPy.

CherryPy mencakup tiga komponen berikut -

  • cherrypy.engine - Ini mengontrol proses startup / teardown dan penanganan acara.

  • cherrypy.server - Ini mengkonfigurasi dan mengontrol server WSGI atau HTTP.

  • cherrypy.tools - Sebuah kotak alat utilitas yang ortogonal untuk memproses permintaan HTTP.

Antarmuka REST melalui CherryPy

Layanan web RESTful mengimplementasikan setiap bagian arsitektur CherryPy dengan bantuan berikut ini -

  • Authentication
  • Authorization
  • Structure
  • Encapsulation
  • Penanganan Error

Autentikasi

Otentikasi membantu dalam memvalidasi pengguna yang berinteraksi dengan kami. CherryPy menyertakan alat untuk menangani setiap metode otentikasi.

def authenticate():
   if not hasattr(cherrypy.request, 'user') or cherrypy.request.user is None:
      # < Do stuff to look up your users >
		
      cherrypy.request.authorized = False # This only authenticates. 
         Authz must be handled separately.
		
      cherrypy.request.unauthorized_reasons = []
      cherrypy.request.authorization_queries = []
		
cherrypy.tools.authenticate = \
   cherrypy.Tool('before_handler', authenticate, priority=10)

Fungsi otentikasi () di atas akan membantu untuk memvalidasi keberadaan klien atau pengguna. Alat bawaan membantu menyelesaikan proses dengan cara yang sistematis.

Otorisasi

Otorisasi membantu menjaga kewarasan proses melalui URI. Proses ini juga membantu mengubah objek dengan petunjuk token pengguna.

def authorize_all():
   cherrypy.request.authorized = 'authorize_all'
	
cherrypy.tools.authorize_all = cherrypy.Tool('before_handler', authorize_all, priority=11)

def is_authorized():
   if not cherrypy.request.authorized:
      raise cherrypy.HTTPError("403 Forbidden",
         ','.join(cherrypy.request.unauthorized_reasons))
			
cherrypy.tools.is_authorized = cherrypy.Tool('before_handler', is_authorized, 
priority = 49)

cherrypy.config.update({
   'tools.is_authorized.on': True,
   'tools.authorize_all.on': True
})

Alat bantu otorisasi bawaan membantu menangani rutinitas secara sistematis, seperti yang disebutkan dalam contoh sebelumnya.

Struktur

Mempertahankan struktur API membantu mengurangi beban kerja pemetaan URI aplikasi. Selalu penting untuk menjaga agar API dapat ditemukan dan bersih. Struktur dasar API untuk kerangka CherryPy harus memiliki yang berikut -

  • Akun dan Pengguna
  • Autoresponder
  • Contact
  • File
  • Folder
  • Daftar dan bidang
  • Pesan dan Batch

Enkapsulasi

Enkapsulasi membantu dalam membuat API yang ringan, dapat dibaca manusia, dan dapat diakses oleh berbagai klien. Daftar item bersama dengan Creation, Retrieval, Update dan Deletion membutuhkan enkapsulasi API.

Penanganan Error

Proses ini mengelola kesalahan, jika ada, jika API gagal dijalankan pada insting tertentu. Misalnya, 400 untuk Permintaan Buruk dan 403 untuk permintaan yang tidak sah.

Contoh

Pertimbangkan hal berikut sebagai contoh untuk database, validasi, atau kesalahan aplikasi.

import cherrypy
import json

def error_page_default(status, message, traceback, version):
   ret = {
      'status': status,
      'version': version,
      'message': [message],
      'traceback': traceback
   }
	
   return json.dumps(ret)
	
class Root:
   _cp_config = {'error_page.default': error_page_default}
	
@cherrypy.expose
   def index(self):
      raise cherrypy.HTTPError(500, "Internal Sever Error")
cherrypy.quickstart(Root())

Kode di atas akan menghasilkan keluaran sebagai berikut -

Manajemen API (Application Programming Interface) mudah dilakukan melalui CherryPy karena alat akses bawaan.

Metode HTTP

Daftar metode HTTP yang beroperasi pada sumber daya adalah sebagai berikut -

S.No Metode & Operasi HTTP
1.

HEAD

Mengambil metadata sumber daya.

2.

GET

Mengambil metadata sumber daya dan konten.

3.

POST

Meminta server untuk membuat sumber daya baru menggunakan data yang disertakan dalam isi permintaan.

4.

PUT

Meminta server untuk mengganti sumber daya yang ada dengan yang disertakan dalam badan permintaan.

5.

DELETE

Meminta server untuk menghapus sumber daya yang diidentifikasi oleh URI tersebut.

6.

OPTIONS

Meminta server untuk memberikan detail tentang kapabilitas baik secara global atau khusus terhadap suatu sumber daya.

Atom Publishing Protocol (APP)

APP telah muncul dari komunitas Atom sebagai protokol tingkat aplikasi di atas HTTP untuk memungkinkan penerbitan dan pengeditan sumber daya web. Unit pesan antara server APP dan klien didasarkan pada format dokumen XML Atom.

Protokol Penerbitan Atom mendefinisikan serangkaian operasi antara layanan APP dan agen pengguna menggunakan HTTP dan mekanismenya serta format dokumen XML Atom sebagai unit pesan.

APP pertama-tama mendefinisikan dokumen layanan, yang memberi agen pengguna URI dari koleksi berbeda yang disajikan oleh layanan APP.

Contoh

Mari kita ambil contoh untuk mendemonstrasikan cara kerja APP -

<?xml version = "1.0" encoding = "UTF-8"?>
<service xmlns = "http://purl.org/atom/app#" xmlns:atom = "http://www.w3.org/2005/Atom">
   
   <workspace>
      <collection href = "http://host/service/atompub/album/">
         <atom:title> Albums</atom:title>
         <categories fixed = "yes">
            <atom:category term = "friends" />
         </categories>
      </collection>
      
      <collection href = "http://host/service/atompub/film/">
         <atom:title>Films</atom:title>
         <accept>image/png,image/jpeg</accept>
      </collection>
   </workspace>
	
</service>

APP menentukan cara melakukan operasi CRUD dasar terhadap anggota koleksi atau koleksi itu sendiri dengan menggunakan metode HTTP seperti yang dijelaskan dalam tabel berikut -

Operasi Metode HTTP Kode status Kandungan
Ambil DAPATKAN 200 Entri Atom yang mewakili sumber daya
Membuat POS 201 URI sumber daya yang baru dibuat melalui header Lokasi dan Lokasi Konten
Memperbarui TARUH 200 Entri Atom yang mewakili sumber daya
Menghapus MENGHAPUS 200 Tidak ada

Lapisan Presentasi memastikan bahwa komunikasi yang melewatinya menargetkan penerima yang dituju. CherryPy mempertahankan kerja lapisan presentasi dengan berbagai mesin templat.

Mesin templat mengambil input dari halaman dengan bantuan logika bisnis dan kemudian memprosesnya ke halaman terakhir yang hanya menargetkan audiens yang dituju.

Kid - Mesin Template

Kid adalah mesin templat sederhana yang menyertakan nama templat yang akan diproses (yang wajib) dan input data yang akan diteruskan saat templat dibuat.

Saat pembuatan template untuk pertama kalinya, Kid membuat modul Python yang dapat disajikan sebagai versi cache dari template.

Itu kid.Template function mengembalikan sebuah instance dari kelas template yang dapat digunakan untuk membuat konten output.

Kelas template menyediakan set perintah berikut -

S.No Perintah & Deskripsi
1.

serialize

Ini mengembalikan konten keluaran sebagai string.

2.

generate

Ini mengembalikan konten keluaran sebagai iterator.

3.

write

Ini membuang konten output ke dalam objek file.

Parameter yang digunakan oleh perintah ini adalah sebagai berikut -

S.No Perintah & Deskripsi
1.

encoding

Ini menginformasikan cara menyandikan konten keluaran

2.

fragment

Ini adalah nilai Boolean yang memberitahu XML prolog atau Doctype

3.

output

Jenis serialisasi ini digunakan untuk merender konten

Contoh

Mari kita ambil contoh untuk memahami caranya kid bekerja -

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html xmlns:py = "http://purl.org/kid/ns#">
   <head>
      <title>${title}</title> <link rel = "stylesheet" href = "style.css" /> </head> <body> <p>${message}</p>
   </body>
</html>

The next step after saving the file is to process the template via the Kid engine.

import kid

params = {'title': 'Hello world!!', 'message': 'CherryPy.'}
t = kid.Template('helloworld.kid', **params)
print t.serialize(output='html')

Atribut Anak

Berikut ini adalah atribut Kid -

Bahasa Templating Berbasis XML

Ini adalah bahasa berbasis XML. Template Anak harus berupa dokumen XML yang dibentuk dengan baik dengan konvensi penamaan yang tepat.

Kid mengimplementasikan atribut dalam elemen XML untuk memperbarui mesin yang mendasari tindakan yang harus diikuti untuk mencapai elemen tersebut. Untuk menghindari tumpang tindih dengan atribut lain yang ada dalam dokumen XML, Kid telah memperkenalkan namespace-nya sendiri.

<p py:if = "...">...</p>

Substitusi Variabel

Kid hadir dengan skema substitusi variabel dan pendekatan sederhana - $ {variable-name}.

Variabel dapat digunakan dalam atribut elemen atau sebagai konten teks suatu elemen. Kid akan mengevaluasi variabel setiap kali eksekusi berlangsung.

Jika pengguna membutuhkan keluaran dari string literal sebagai $ {sesuatu}, itu bisa di-escape menggunakan substitusi variabel dengan menggandakan tanda dolar.

Pernyataan Bersyarat

Untuk mengganti kasus yang berbeda dalam template, sintaks berikut digunakan -

<tag py:if = "expression">...</tag>

Di sini, tag adalah nama elemen, misalnya DIV atau SPAN.

Ekspresi tersebut adalah ekspresi Python. Jika sebagai Boolean terevaluasi menjadi True, elemen tersebut akan disertakan dalam konten output atau tidak akan menjadi bagian dari konten output.

Mekanisme Pendauran

Untuk mengulang elemen di Kid, sintaks berikut digunakan -

<tag py:for = "expression">...</tag>

Di sini, tag adalah nama elemen. Ekspresi tersebut adalah ekspresi Python, misalnya untuk nilai dalam [...].

Contoh

Kode berikut menunjukkan bagaimana mekanisme perulangan bekerja -

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
   <head>
      <title>${title}</title> <link rel = "stylesheet" href = "style.css" /> </head> <body> <table> <caption>A few songs</caption> <tr> <th>Artist</th> <th>Album</th> <th>Title</th> </tr> <tr py:for = "info in infos"> <td>${info['artist']}</td>
            <td>${info['album']}</td> <td>${info['song']}</td>
         </tr>
      </table>
   </body>
</html>

import kid

params = discography.retrieve_songs()
t = kid.Template('songs.kid', **params)
print t.serialize(output='html')

Itu output untuk kode diatas dengan mekanisme perulangan adalah sebagai berikut -

Hingga tahun 2005, pola yang diikuti di semua aplikasi web adalah mengelola satu permintaan HTTP per halaman. Navigasi dari satu halaman ke halaman lain membutuhkan memuat halaman lengkap. Ini akan menurunkan kinerja pada level yang lebih tinggi.

Jadi, terjadi peningkatan rich client applications yang digunakan untuk menyematkan AJAX, XML, dan JSON dengannya.

AJAX

Asynchronous JavaScript and XML (AJAX) adalah teknik untuk membuat halaman web yang cepat dan dinamis. AJAX memungkinkan halaman web diperbarui secara asynchronous dengan menukar sejumlah kecil data di belakang layar dengan server. Ini berarti dimungkinkan untuk memperbarui bagian dari halaman web, tanpa memuat ulang seluruh halaman.

Google Maps, Gmail, YouTube, dan Facebook adalah beberapa contoh aplikasi AJAX.

Ajax didasarkan pada gagasan mengirim permintaan HTTP menggunakan JavaScript; lebih khusus lagi AJAX bergantung pada objek XMLHttpRequest dan API-nya untuk melakukan operasi tersebut.

JSON

JSON adalah cara untuk membawa objek JavaScript berseri sedemikian rupa sehingga aplikasi JavaScript dapat mengevaluasinya dan mengubahnya menjadi objek JavaScript yang dapat dimanipulasi nanti.

Misalnya, ketika pengguna meminta server untuk objek album yang diformat dengan format JSON, server akan mengembalikan output sebagai berikut -

{'description': 'This is a simple demo album for you to test', 'author': ‘xyz’}

Sekarang datanya adalah array asosiatif JavaScript dan bidang deskripsi dapat diakses melalui -

data ['description'];

Menerapkan AJAX ke Aplikasi

Pertimbangkan aplikasi yang menyertakan folder bernama "media" dengan index.html dan plugin Jquery, dan file dengan implementasi AJAX. Mari kita pertimbangkan nama file sebagai "ajax_app.py"

ajax_app.py

import cherrypy
import webbrowser
import os
import simplejson
import sys

MEDIA_DIR = os.path.join(os.path.abspath("."), u"media")

class AjaxApp(object):
   @cherrypy.expose
   def index(self):
      return open(os.path.join(MEDIA_DIR, u'index.html'))

   @cherrypy.expose
   def submit(self, name):
      cherrypy.response.headers['Content-Type'] = 'application/json'
      return simplejson.dumps(dict(title="Hello, %s" % name))
		
config = {'/media':
   {'tools.staticdir.on': True,
   'tools.staticdir.dir': MEDIA_DIR,}
}
			
def open_page():
webbrowser.open("http://127.0.0.1:8080/")
cherrypy.engine.subscribe('start', open_page)
cherrypy.tree.mount(AjaxApp(), '/', config=config)
cherrypy.engine.start()

Kelas "AjaxApp" dialihkan ke halaman web "index.html", yang termasuk dalam folder media.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
   " http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
	
<html xmlns = "http://www.w3.org/1999/xhtml" lang = "en" xml:lang = "en">
   <head>
      <title>AJAX with jQuery and cherrypy</title>
      <meta http-equiv = " Content-Type" content = " text/html; charset=utf-8" />
      <script type = " text/javascript" src = " /media/jquery-1.4.2.min.js"></script>
		
      <script type = " text/javascript">
         $(function() { // When the testform is submitted... $("#formtest").submit(function() {
         
               // post the form values via AJAX...
               $.post('/submit', {name: $("#name").val()}, function(data) {
         
                  // and set the title with the result
                  $("#title").html(data['title']) ;
               });
               return false ;
            });
         });
      </script>
		
   </head>
	
   <body>
      <h1 id = "title">What's your name?</h1>
      <form id = " formtest" action = " #" method = " post">
         <p>
            <label for = " name">Name:</label>
            <input type = " text" id = "name" /> <br />
            <input type = " submit" value = " Set" />
         </p>
      </form>
   </body>
	
</html>

Fungsi untuk AJAX disertakan dalam tag <script>.

Keluaran

Kode di atas akan menghasilkan keluaran sebagai berikut -

Setelah nilai dikirimkan oleh pengguna, fungsionalitas AJAX diimplementasikan dan layar dialihkan ke formulir seperti yang ditunjukkan di bawah ini -

Pada bab ini, kita akan fokus pada bagaimana sebuah aplikasi dibuat dalam framework CherryPy.

Mempertimbangkan Photoblogaplikasi untuk aplikasi demo CherryPy. Aplikasi Photoblog adalah blog biasa tetapi teks utamanya adalah foto menggantikan teks. Hasil utama dari aplikasi Photoblog adalah pengembang dapat lebih fokus pada desain dan implementasi.

Struktur Dasar - Desain Entitas

Entitas merancang struktur dasar aplikasi. Berikut entitas untuk aplikasi Photoblog -

  • Film
  • Photo
  • Album

Berikut ini adalah diagram kelas dasar untuk relasi entitas -

Struktur Desain

Seperti yang dibahas di bab sebelumnya, struktur desain proyek akan seperti yang ditunjukkan pada tangkapan layar berikut -

Pertimbangkan aplikasi yang diberikan, yang memiliki sub-direktori untuk aplikasi Photoblog. Sub-direktori adalah Foto, Album, dan Film yang akan menyertakan controllers.py, models.py dan server.py.

Secara fungsional, aplikasi Photoblog akan menyediakan API untuk memanipulasi entitas tersebut melalui antarmuka CRUD tradisional - Buat, Ambil, Perbarui, dan Hapus.

Koneksi ke Database

Modul penyimpanan mencakup serangkaian operasi; koneksi dengan database menjadi salah satu operasi.

Karena ini adalah aplikasi yang lengkap, koneksi dengan database adalah wajib untuk API dan untuk memelihara fungsionalitas dari Buat, Ambil, Perbarui, dan Hapus.

import dejavu

arena = dejavu.Arena()
from model import Album, Film, Photo
def connect():

conf = {'Connect': "host=localhost dbname=Photoblog user=test password=test"}
arena.add_store("main", "postgres", conf)
arena.register_all(globals())

Arena dalam kode di atas akan menjadi antarmuka antara pengelola penyimpanan yang mendasari dan lapisan logika bisnis.

Fungsi menghubungkan menambahkan manajer penyimpanan ke objek arena untuk RDBMS PostgreSQL.

Setelah koneksi diperoleh, kami dapat membuat formulir sesuai kebutuhan bisnis dan menyelesaikan pekerjaan aplikasi.

Hal terpenting sebelum membuat aplikasi apa pun adalah entity mapping dan mendesain struktur aplikasi.

Pengujian adalah proses di mana aplikasi dilakukan dari perspektif yang berbeda untuk -

  • Temukan daftar masalah
  • Temukan perbedaan antara hasil, keluaran, status, dll. Yang diharapkan dan aktual.
  • Pahami fase implementasi.
  • Temukan aplikasi yang berguna untuk tujuan realistis.

Tujuan pengujian bukan untuk menyalahkan pengembang, tetapi untuk menyediakan alat dan meningkatkan kualitas untuk memperkirakan kesehatan aplikasi pada waktu tertentu.

Pengujian perlu direncanakan sebelumnya. Ini panggilan untuk menentukan tujuan pengujian, memahami ruang lingkup kasus uji, membuat daftar persyaratan bisnis dan menyadari risiko yang terlibat dalam berbagai fase proyek.

Pengujian didefinisikan sebagai berbagai aspek yang akan divalidasi pada sistem atau aplikasi. Berikut ini adalah daftar daricommon test approaches -

  • Unit testing- Ini biasanya dilakukan oleh pengembang sendiri. Ini bertujuan untuk memeriksa apakah suatu unit kode berfungsi seperti yang diharapkan atau tidak.

  • Usability testing- Pengembang biasanya lupa bahwa mereka sedang menulis aplikasi untuk pengguna akhir yang tidak memiliki pengetahuan tentang sistem. Pengujian kegunaan memverifikasi pro dan kontra produk.

  • Functional/Acceptance testing - Sementara pengujian kegunaan memeriksa apakah suatu aplikasi atau sistem dapat digunakan, pengujian fungsional memastikan bahwa setiap fungsionalitas yang ditentukan diimplementasikan.

  • Load and performance testing- Hal ini dilakukan untuk mengetahui apakah sistem dapat menyesuaikan dengan beban dan uji kinerja yang akan dilakukan. Ini dapat menyebabkan perubahan pada perangkat keras, mengoptimalkan kueri SQL, dll.

  • Regression testing - Ini memverifikasi bahwa rilis produk yang berurutan tidak merusak fungsi sebelumnya.

  • Reliability and resilience testing - Pengujian reliabilitas membantu dalam memvalidasi aplikasi sistem dengan kerusakan satu atau beberapa komponen.

Pengujian Unit

Aplikasi Photoblog secara konstan menggunakan pengujian unit untuk memeriksa hal-hal berikut -

  • Fungsionalitas baru bekerja dengan benar dan seperti yang diharapkan.
  • Fungsi yang sudah ada tidak rusak oleh rilis kode baru.
  • Cacat diperbaiki dan tetap diperbaiki.

Python hadir dengan modul unittest standar yang menawarkan pendekatan berbeda untuk pengujian unit.

Unittest

unittest berakar pada JUnit, paket pengujian unit Java yang dikembangkan oleh Kent Beck dan Erich Gamma. Tes unit hanya mengembalikan data yang ditentukan. Objek tiruan dapat didefinisikan. Objek-objek ini memungkinkan pengujian terhadap antarmuka desain kami tanpa harus bergantung pada aplikasi secara keseluruhan. Mereka juga menyediakan cara untuk menjalankan pengujian dalam mode isolasi dengan pengujian lain yang disertakan.

Mari kita definisikan kelas dummy dengan cara berikut -

import unittest

class DummyTest(unittest.TestCase):
def test_01_forward(self):
dummy = Dummy(right_boundary=3)
   self.assertEqual(dummy.forward(), 1)
   self.assertEqual(dummy.forward(), 2)
   self.assertEqual(dummy.forward(), 3)
   self.assertRaises(ValueError, dummy.forward)

def test_02_backward(self):
dummy = Dummy(left_boundary=-3, allow_negative=True)
   self.assertEqual(dummy.backward(), -1)
   self.assertEqual(dummy.backward(), -2)
   self.assertEqual(dummy.backward(), -3)
   self.assertRaises(ValueError, dummy.backward)

def test_03_boundaries(self):
dummy = Dummy(right_boundary=3, left_boundary=-3,allow_negative=True)
   self.assertEqual(dummy.backward(), -1)
   self.assertEqual(dummy.backward(), -2)
   self.assertEqual(dummy.forward(), -1)
   self.assertEqual(dummy.backward(), -2)
   self.assertEqual(dummy.backward(), -3)

Penjelasan kode tersebut adalah sebagai berikut -

  • modul unittest harus diimpor untuk memberikan kemampuan pengujian unit untuk kelas yang diberikan.

  • Sebuah kelas harus dibuat dengan subclassing unittest.

  • Setiap metode dalam kode di atas dimulai dengan tes kata. Semua metode ini dipanggil oleh penangan unittest.

  • Metode assert / fail dipanggil oleh kasus uji untuk mengelola pengecualian.

Pertimbangkan ini sebagai contoh untuk menjalankan kasus uji -

if __name__ == '__main__':
unittest.main()

Hasil (output) untuk menjalankan test case adalah sebagai berikut -

----------------------------------------------------------------------
Ran 3 tests in 0.000s
OK

Pengujian Fungsional

Setelah fungsionalitas aplikasi mulai terbentuk sesuai kebutuhan, serangkaian pengujian fungsional dapat memvalidasi kebenaran aplikasi terkait spesifikasi. Namun, pengujian tersebut harus diotomatiskan untuk performa yang lebih baik yang akan membutuhkan penggunaan produk pihak ketiga seperti Selenium.

CherryPy menyediakan kelas pembantu seperti fungsi bawaan untuk memudahkan penulisan tes fungsional.

Pengujian Beban

Bergantung pada aplikasi yang Anda tulis dan harapan Anda dalam hal volume, Anda mungkin perlu menjalankan pengujian beban dan kinerja untuk mendeteksi potensi kemacetan dalam aplikasi yang mencegahnya mencapai tingkat kinerja tertentu.

Bagian ini tidak akan merinci bagaimana melakukan tes kinerja atau beban karena itu di luar paket FunkLoad-nya.

Contoh dasar FunkLoad adalah sebagai berikut -

from funkload.FunkLoadTestCase 
import FunkLoadTestCase

class LoadHomePage(FunkLoadTestCase):
def test_homepage(self):

server_url = self.conf_get('main', 'url')
nb_time = self.conf_getInt('test_homepage', 'nb_time')
home_page = "%s/" % server_url

for i in range(nb_time):
self.logd('Try %i' % i)
self.get(home_page, description='Get gome page')
if __name__ in ('main', '__main__'):

import unittest

unittest.main()

Berikut penjelasan detail dari kode diatas -

  • Kasus pengujian harus mewarisi dari kelas FunkLoadTestCase sehingga FunkLoad dapat melakukan tugas internalnya untuk melacak apa yang terjadi selama pengujian.

  • Nama kelas penting karena FunkLoad akan mencari file berdasarkan nama kelas.

  • Kasus uji yang dirancang memiliki akses langsung ke file konfigurasi. Metode get () dan post () dipanggil ke server untuk mendapatkan respons.

Bab ini akan lebih fokus pada SSL aplikasi berbasis CherryPy yang diaktifkan melalui server HTTP CherryPy bawaan.

Konfigurasi

Ada berbagai tingkat pengaturan konfigurasi yang diperlukan dalam aplikasi web -

  • Web server - Pengaturan yang terhubung ke server HTTP

  • Engine - Pengaturan yang terkait dengan hosting mesin

  • Application - Aplikasi yang digunakan oleh pengguna

Penyebaran

Penyebaran aplikasi CherryPy dianggap sebagai metode yang cukup mudah di mana semua paket yang diperlukan tersedia dari jalur sistem Python. Dalam lingkungan web-host bersama, server web akan berada di ujung depan yang memungkinkan penyedia host untuk melakukan tindakan pemfilteran. Server front-end dapat berupa Apache ataulighttpd.

Bagian ini akan menyajikan beberapa solusi untuk menjalankan aplikasi CherryPy di ​​belakang server web Apache dan lighttpd.

cherrypy
def setup_app():

class Root:
@cherrypy.expose
def index(self):
   # Return the hostname used by CherryPy and the remote
   # caller IP address
	
return "Hello there %s from IP: %s " %
(cherrypy.request.base, cherrypy.request.remote.ip)
cherrypy.config.update({'server.socket_port': 9091,
   'environment': 'production',
   'log.screen': False,
   'show_tracebacks': False})
	
cherrypy.tree.mount(Root())
if __name__ == '__main__':

setup_app()
cherrypy.server.quickstart()
cherrypy.engine.start()

SSL

SSL (Secure Sockets Layer)dapat didukung dalam aplikasi berbasis CherryPy. Untuk mengaktifkan dukungan SSL, persyaratan berikut harus dipenuhi -

  • Memiliki paket PyOpenSSL diinstal di lingkungan pengguna
  • Memiliki sertifikat SSL dan kunci pribadi di server

Membuat Sertifikat dan Kunci Pribadi

Mari kita berurusan dengan persyaratan sertifikat dan kunci pribadi -

  • Pertama, pengguna membutuhkan kunci pribadi -
openssl genrsa -out server.key 2048
  • Kunci ini tidak dilindungi oleh kata sandi dan karena itu memiliki perlindungan yang lemah.
  • Perintah berikut akan dikeluarkan -
openssl genrsa -des3 -out server.key 2048
  • Program ini akan membutuhkan kata sandi. Jika versi OpenSSL Anda memungkinkan Anda memberikan string kosong, lakukanlah. Jika tidak, masukkan frasa sandi default dan kemudian hapus dari kunci yang dihasilkan seperti berikut -

openssl rsa -in server.key -out server.key
  • Pembuatan sertifikat adalah sebagai berikut -
openssl req -new -key server.key -out server.csr
  • Proses ini akan meminta Anda untuk memasukkan beberapa detail. Untuk melakukannya, perintah berikut harus dikeluarkan -

openssl x509 -req -days 60 -in server.csr -signkey
server.key -out server.crt
  • Sertifikat yang baru ditandatangani akan berlaku selama 60 hari.

Kode berikut menunjukkan implementasinya -

import cherrypy
import os, os.path

localDir = os.path.abspath(os.path.dirname(__file__))
CA = os.path.join(localDir, 'server.crt')
KEY = os.path.join(localDir, 'server.key')
def setup_server():

class Root:
@cherrypy.expose
def index(self):
   return "Hello there!"
	
cherrypy.tree.mount(Root())
if __name__ == '__main__':

setup_server()
cherrypy.config.update({'server.socket_port': 8443,
   'environment': 'production',
   'log.screen': True,
   'server.ssl_certificate': CA,
   'server.ssl_private_key': KEY})
	
cherrypy.server.quickstart()
cherrypy.engine.start()

Langkah selanjutnya adalah memulai server; jika Anda berhasil, Anda akan melihat pesan berikut di layar Anda -

HTTP Serving HTTPS on https://localhost:8443/