Skip to main content

Expanding your app with Fathym

Using the zip deployment artifact can be a quick and easy way to get started with Fathym, but it may not be the most efficient or effective way to organize and manage your code over time. To make your code more manageable and scalable, it is often useful to set up a more permanent structure for your code using a version control system like Git, which can be hosted on a platform like GitHub. This allows you to track changes to your code over time, collaborate with others on your project, and easily roll back changes if necessary.

CI/CD with GitHub and Fathym

Continuous integration (CI) and continuous deployment (CD) are key practices in the field of DevOps that help teams efficiently develop and deploy software. CI involves regularly integrating code changes into a shared repository, while CD involves automatically building, testing, and deploying code changes to production environments. These practices help teams identify and fix errors early in the development process, and allow them to deliver new features and updates more quickly and with fewer errors.

GitHub is a web-based platform used for version control, collaboration, and code hosting. Its features, such as issue tracking and project management, can be leveraged to support the CI/CD process. GitHub also provides GitHub Actions, which can be used to automate the CI/CD process. By using GitHub and Fathym together, you can set up automated workflows to build, test, and deploy your code whenever certain events occur, helping you streamline your development and deployment process and deliver new features and updates to users more efficiently.

Fathym helps to configure the repository for automated builds and deployments for testing on main/master, integration, feature, and hotfix branches. In addition to setting up the code and build phases, Fathym provides the necessary automation for release and deployment to streamline the code-to-deploy workflow. This allows teams to efficiently develop and deploy software, resulting in faster delivery of new features and updates to users.

Configuring your Source Code

For the reason mentioned above, we are going to move our code off the file system. The first thing you'll need to do is authorize with GitHub. Head back into VS Code and into a terminal where we will auth the user of the CLI with GitHub (in the user's global GitHub auth for the active EaC).

fathym git auth

This will open a new window with GitHub authorization where you can determine which organizations Fathym has access to (you may have to sign up if you have not before). Grant access to the organizations you'd like us to help you manage and automate.

note

You can run this command anytime you want to adjust the authorizations in GitHub for new or existing organizations.

Now let's create a new repository in one of the organizations you authorized Fathym for.

ftm git configure -s

This does a number of things to set up your repository, including branch setup and configurations to support the default Git workflow.

note

You may have noticed the use of ftm here. The Fathym CLI can be accessed in two ways, fathym or the shorthand ftm. Both can be used interchangeably for any of the commands. The previous command could have been replaced with fathym git configure -s with the same outcome.

Let's clone our new repository and we'll continue to work on it. Follow the prompts and select the organization and repository you just initialized. Make sure to navigate into a folder where you would like to organize your repositories.

fathym git clone

Next move into the repository folder.

cd .\{name-of-new-repo}

Preparing for local development

A few things have changed in our code so let's take a look. Start by opening your code.

fathym open

And then lets sync our local.

fathym git

This command does a few things in addition to the standard git pull that helps to keep your development branch in sync with integration and other development from your team.

Configuring your build pipeline

As mentioned previously, there are many different ways to get your deployment artifacts into Fathym. You'll move from the zip deploy to something automated in GitHub. To do that, you'll configure a build pipeline for the new source control.

A build pipeline is a configuration of the build process. It is made up of a template and the parameters necessary to fulfill the chosen template. A source control can only have a single build pipeline while a build pipeline can have multiple source controls. This ensures understanding on how a source control is built, and allows you to make edits to a build pipeline that update multiple source controls at the same time (like a series of React builds). This helps keep your GitHub Actions in sync as your architecture evolves.

To start, we need to define the source control in our EaC. This will add a source definition to our draft. Select the organization and repository you used previously.

fathym eac env sources define

Now we'll use another LCU to get a root static build going for our simple code base. There are equivalent commands in the CLI to use, though often the LCUs serve as a quicker way to integrate solutions (even if you need to build them yourself).

fathym lcu @fathym-it/lcu-eac-pipelines-root-static

Once the build pipeline is defined, you can now attach it to the source control.

fathym eac env sources pipeline attach

Now we need to commit all of our EaC changes for the source and build pipelines.

fathym eac commit "Configured source and builds for {username/organization} my-new-repository"

Once the commit completes the source will be created with a new GitHub Action. It should start and run automatically.

note

If the GitHub Action does not start automatically, you may need to enable actions for your repository. Once done, a build will start on your next committed change (which we will do shortly).

This is a big step for you and/or team, as you've set up a complete continuous integration workflow to automate your project builds. You've also laid the ground work for continuous deployment.

Continuing development

Now you have a continuous integration flow in place and a better understanding of how your branching strategy is configured, so let's start using it all.

First, create a new branch in your repository.

fathym git feature add-index-html-template

You'll notice you are now on the feature/add-index-html-templates branch and we can start coding. Add a new index.html file.

npx touch index.html

Then open that file and set some boilerplate HTML.

fathym open index.html

Once open, add the following HTML, save, and then close the file.

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>My Fathym App</title>

<style>
body {
background-color: black;
color: white;
}
</style>
</head>
<body>
<header>
<h1>Welcome to Fathym</h1>
</header>

<nav>
<a href="./README.md">Readme</a>
</nav>

<div id="fathym-compose">
<h1>My Fathym App</h1>

<p>The first set of content for my app landing page.</p>
</div>

<footer>Copyright &copy; 2023</footer>
</body>
</html>

Take note of the div with id fathym-compose, you'll need this id later when configuring Fathym Runtime server-side composition.

Update the README.md file with whatever markdown you want to use. We support a large portion of the CommonMark spec via the work done by xoofx/markdig. You can also update the HTML template with additional markup.

Now you are ready to check in and push your code.

fathym git "Added index.html template"

You'll see we are using the fathym git command again, this time specifying a message because we know there were changes. If the message were omitted and changes detected, you would be prompted for a message.

Upon pushing your changes to the repository, you'll be able to see the build in progress. You can view this in the Actions tab of the repository on GitHub.

fathym git home -s actions

Alternatively, you can use your Fathym enterprise feed to see all build activity (and more) at a glance.

Deploy the GitHub artifact

The build should complete very quickly because you aren't really building anything. You'll notice, if you look at your action file, that it is simply exporting everything at the root of your repository as a GitHub build artifact.

In order to deploy that artifact, you'll need to create a new application again, this time for our GitHub sample.

note

If you haven't created a project yet, head to the previous walkthrough. If you don't have your project lookup and need to find it, you can use fathym eac projects list.

We'll use another LCU Package here to quickly install our GitHub application.

fathym lcu @fathym-it/lcu-eac-applications-lcu-github

Follow the prompts and select your existing project and select the GitHub source control created earlier. Finally input something like /github-app for the path. Once completed, a new application, lookup, lcu, and processor will have been configured as we did in the zip example, except this time interactively with the LCU package.

note

Notice the source control being attached to the application, this sets the application up to receive automatic deployments and will alter the GitHub Action for this purpose.

Let's preview our new application:

fathym eac projects applications preview

Exploring the Distributed File System (DFS) and Modifiers

We won't go into too much detail on the DFS yet, but it's important to note that when your deployment artifacts are uploaded to Fathym they are stored in the DFS. The Fathym Runtime then works with the DFS to determine which files to serve for a given request.

Once a file is chosen for a request it will pass through any configured modifiers. These modifiers will act on the file to change it (minify, compress), augment it (google analytics tracking, cookie consent integration), or compose it (wordpress, markdown, BaseHref).

note

You can head in to the DFS and Modifiers to learn more.

Configuring the markdown composition

In the first guide we demonstrated how markdown can be converted into HTML. We hooked that DFS modifier up for all applications in the project, so let's see it working here as well.

fathym eac projects applications preview -p /README.md

Let's introduce another feature of the Fathym Runtime, server-side composition. In order to enable markdown composition with your index.html file, you'll need to set up another modifier. The new one will work with converted HTML, the HTML Composer Modifier. It will format the HTML into a configured template.

Next you will configure the modifier that will compose the formatted markdown into the HTML template (index.html). Set the name of the modifier to HTML Markdown Composer, the modifier lookup to html-markdown-composer, the path regex to .*.(md|mdx).*, the template path to ./index.html, and the xpath target to //div[@id='fathym-compose'].

fathym lcu @fathym-it/lcu-eac-modifiers-html-composer
note

The priority is important to ensure modifiers execute in the correct order. Higher priority modifiers execute first, then lower priority ones. Modifiers with the same priority execute in parallel. The LCU packages help manage modifiers by our (and the communities) own internal best practice configurations.

With the new modifier created, you'll need to add it to the project again for use.

fathym eac projects modifiers add

This will create the final aspect of our initial modifier flow, and once committed, you'll be able to preview it in your browser.

fathym eac commit "Configured second application in project"
fathym eac projects applications preview -p README.md

Finalizing our feature development

As we finish our feature development, and it passes feature testing, we will need to make sure that we open a pull request to integration to have our changes incorporated. We can do this using the following command.

fathym git feature integrate

This pull request will be opened following the configuration that we used at the beginning of this guide. To approve and view your pull request, run:

fathym git home -s pulls

Also, if you go look at your builds again (either in the enterprise feed or on GitHub) you'll see that builds have been executing for all of your branches.

What's Next?

There is a lot that you have set up over the course of these walkthroughs. You've created a complete CI/CD workflow to take you through code-to-deploy. Next, you'll expand what you've been doing with this app to bring in React and TailwindCSS. We'll also introduce one more type of deployment artifact, the one our team prefers: NPM. This enables additional team workflows for testing and release management.