Your task this week is to deploy and test the library app you have completed in the previous two weeks.
Before you start you need to create a testing and deployment plan. We would like you to plan a testing strategy that will have broad coverage of your project. The tools we would like you to use to achieve this can include Cypress, Postman and the Node built in testing library.
We would also like you to deploy this project using an EC2 instance for you server and a S3 bucket to serve your static files using CloudFront. You should also utilise Github actions to allow you to automatically deploy changes on merges to your main branch.
What parts of the application logic are the most critical to cover with unit tests?
How will you mock external dependencies (like databases or APIs) during unit testing?
What are the key user journeys and flows within the application that must be covered by end-to-end tests?
Where will the code that represents your infrastructure live and how will it be organised?
How will you manage configuration variables for different environments (development, staging, production)?
What are the different AWS products you will need to configure to make your deployment successful?
Monday: Exploring Deployment Options
Objectives:
Learn about standard WordPress hosting solutions.
Compare AWS with managed WordPress hosting providers.
Activities:
Research Hosting Providers:
Managed WordPress Hosts:
SiteGround:
Visit SiteGround WordPress Hosting.
Note features like WordPress-specific optimizations, staging environments, and support.
Bluehost:
Visit Bluehost WordPress Hosting.
Check for one-click WordPress installs, free domain, and SSL certificate.
WP Engine:
Visit WP Engine.
Explore managed hosting features like advanced security, global CDN, and development environments.
Features to Consider:
Performance Optimization:
Server configurations.
Use of caching technologies.
CDN availability.
Security Features:
SSL certificates.
Malware scanning.
Firewall protection.
Customer Support:
Availability of 24/7 support.
Support channels (chat, phone, email).
Pricing Plans:
Monthly vs. annual pricing.
Introductory offers and renewal rates.
Understand Benefits of Managed Hosting:
Ease of Use:
Simplified setup processes.
Pre-configured WordPress environments.
Performance:
Servers optimized specifically for WordPress.
Built-in caching and performance enhancements.
Security:
Regular security updates.
Proactive monitoring for vulnerabilities.
Compare with AWS:
AWS Flexibility:
Ability to customize server environments.
Scalability options.
Complexity:
Requires knowledge of server management.
Setup can be more time-consuming.
Cost Considerations:
Potentially lower costs at scale.
Pay-as-you-go pricing model.
Decide on Hosting Solution:
Factors to Consider:
Learning Objectives:
Do you want to learn server management alongside WordPress?
Budget Constraints:
What is the acceptable cost per month/year?
Time Available for Setup:
Is there time to manage servers, or is a managed solution preferable?
Make a Decision:
Choose the hosting provider that best fits your project needs.
Tuesday: Preparing for Deployment
Objectives:
Set up the chosen hosting environment.
Migrate the local WordPress site to the hosting server.
Activities:
Set Up Hosting Environment:
Sign Up for Hosting:
Follow the sign-up process for your chosen hosting provider.
Note down important details like login credentials, server IP, and nameservers.
Set Up Domain (if applicable):
Register a Domain:
If you need a new domain, register one through your hosting provider or a domain registrar like Namecheap.
Update Nameservers:
Point your domain to your hosting provider's nameservers.
Export Local Database:
Use phpMyAdmin
:
Access phpMyAdmin
via http://localhost/phpmyadmin/
.
Select your WordPress database (e.g., wordpress_db
).
Click on the Export
tab.
Choose the Quick
export method and format as SQL.
Click Go
to download the database export file.
Import Database to Server:
Access Server's phpMyAdmin
:
Log in to your hosting account's control panel (e.g., cPanel).
Open phpMyAdmin
from the control panel.
Create a new database (e.g., yourusername_wpdb
).
Create a new database user and assign it to the database with all privileges.
Select the new database.
Click on the Import
tab.
Choose the SQL file exported earlier and click Go
to import.
Upload WordPress Files:
Use FTP Client (e.g., FileZilla):
Install FileZilla: If not already installed, download from FileZilla.
Connect to the Server:
Host: Your domain or server IP.
Username: Your FTP username.
Password: Your FTP password.
Port: Usually 21.
Upload Files:
Navigate to the public_html
or www
directory on the server.
Upload all files and folders from your local WordPress directory.
Configure wp-config.php
:
Update Database Credentials:
Open wp-config.php
in a text editor.
Update the following lines with your server database credentials:
Update Site URLs:
Add the following lines to temporarily define site URLs:
Test the Site:
Access the Site via Browser:
Navigate to http://yourdomain.com
.
Check if the site loads correctly.
Troubleshoot Issues:
Common Issues:
Database connection errors.
Missing files or permissions errors.
Solutions:
Double-check database credentials in wp-config.php
.
Ensure all files are uploaded.
Check file permissions (usually folders 755, files 644).
Wednesday: Securing and Optimizing the Site
Objectives:
Implement security best practices.
Optimize the site's performance.
Activities:
Install SSL Certificate:
Use Let's Encrypt (if supported):
Access Control Panel:
Go to your hosting control panel.
Find SSL/TLS Settings:
Locate the SSL/TLS or Let's Encrypt option.
Install SSL Certificate:
Follow the prompts to install a free SSL certificate for your domain.
Force HTTPS:
Update .htaccess
File:
Add the following code at the top of your .htaccess
file to redirect all traffic to HTTPS:
Update WordPress Settings:
In the WordPress admin dashboard, go to Settings > General
.
Update WordPress Address (URL)
and Site Address (URL)
to use https://
.
Set Up Security Plugins:
Install Wordfence Security Plugin:
In the WordPress admin dashboard, go to Plugins > Add New
.
Search for "Wordfence Security".
Install and activate the plugin.
Configure Wordfence:
Follow the setup wizard.
Enable firewall and scan options.
Configure login security settings.
Implement Caching for Performance:
Install WP Super Cache Plugin:
Go to Plugins > Add New
.
Search for "WP Super Cache".
Install and activate the plugin.
Configure Caching Options:
Go to Settings > WP Super Cache
.
Enable Caching.
Choose Simple
caching method.
Advanced Settings (Optional):
Configure CDN support if using a CDN.
Enable compression.
Optimize Images and Assets:
Install Smush Image Compression Plugin:
Go to Plugins > Add New
.
Search for "Smush".
Install and activate the plugin.
Bulk Optimize Images:
Go to Media > Bulk Smush
.
Optimize existing images.
Enable Automatic Optimization:
Configure settings to automatically optimize images on upload.
Minify CSS and JavaScript with Autoptimize:
Install and activate the "Autoptimize" plugin.
Go to Settings > Autoptimize
.
Enable options to optimize HTML, JavaScript, and CSS.
Check Site Performance:
Use GTmetrix:
Visit GTmetrix.
Enter your site URL and analyze.
Use Google PageSpeed Insights:
Visit PageSpeed Insights.
Enter your site URL and analyze.
Review Recommendations:
Identify areas for improvement.
Implement suggestions as feasible.
Thursday: Final Adjustments and Presentation
Objectives:
Finalize the deployment of the WordPress site.
Prepare and deliver the final 20-minute presentation.
Allocate time for presentation preparation.
Engage in normal development activities.
Activities:
Morning Development:
Finalize Deployment:
Double-Check Functionality:
Test all site features, including custom theme and plugin functionalities.
Fix Any Remaining Issues:
Address any bugs or errors found during testing.
Perform Final Testing:
Cross-Browser Testing:
Test the site on multiple browsers (Chrome, Firefox, Edge, Safari).
Mobile Responsiveness:
Test the site on mobile devices or use browser developer tools.
Presentation Preparation (1 hour):
Summarize Project Journey:
Outline the project's objectives, progress, and outcomes.
Prepare Presentation Materials:
Create slides highlighting key features.
Include screenshots and code snippets where appropriate.
Prepare a live demo of the deployed site.
Rehearse:
Practice the presentation to ensure it fits within the 20-minute time limit.
Deliver the Presentation (20 minutes):
Presentation Structure:
Introduction:
Briefly introduce yourself and the project.
Project Overview:
Discuss the project's goals and scope.
Demonstration:
Showcase the live site.
Navigate through key features.
Highlight custom theme and plugin functionalities.
Technical Deep-Dive:
Explain complex components.
Show relevant code snippets.
Discuss challenges and how you overcame them.
Conclusion:
Summarize accomplishments.
Mention possible future improvements.
Engage with the Audience:
Invite questions and feedback.
Afternoon Development:
Implement Feedback:
Address any immediate feedback from the presentation.
Begin Project Documentation:
Start compiling user guides and technical documentation.
Advanced PHP Concepts:
Learn Object-Oriented Programming (OOP):
Implement Classes and Objects in Your Plugin:
Refactor parts of your plugin to use classes.
Example Class Structure:
Benefits of OOP:
Encapsulation of functionality.
Easier maintenance and scalability.
Resources:
Use Namespaces and Autoloading:
Organize Code Using Namespaces:
Add namespaces to your classes.
Implement PSR-4 Autoloading:
Use Composer for autoloading classes.
Install Composer:
Download from getcomposer.org.
Create composer.json
:
Run Composer Dump-Autoload:
Include Autoloader in Plugin:
Resources:
Security Best Practices:
Deep Dive into WordPress Security:
Further Hardening WordPress:
Change default table prefixes.
Disable file editing from the admin dashboard.
Limit login attempts.
Stay Updated:
Regularly update WordPress core, themes, and plugins.