A small Multi-Programming-Language project designed to compare the efficiency of the particular languages in use when performing the exact same task on various resource consumption fronts.
The Project is based on a Vue.JS 3 front-end and UI, with a Node.JS backend API.
The Hosting of the Vue UI is done on GitHub Pages with the Node API running on Netlify's free tier.
If you haven't already created a Vue.js project, follow these steps:
# Install Vue CLI globally if you haven't
npm install -g @vue/cli
# Create a new Vue.js project
vue create benchmark-comparison
# Navigate to the project directory
cd benchmark-comparison
In the root of your project, create a vue.config.js
file to specify the publicPath needed for GitHub Pages. Replace <your-repo-name>
with your actual repository name on GitHub or any other Version Control platform you'd like to use.
See Configuration Reference for more detailed information if needed.
// vue.config.ts
module.exports = {
...
publicPath:
process.env.NODE_ENV === "production" ? "/<your-repo-name>/" : "/",
};
We'll build a simple Vue component that fetches benchmark results from the Node backend API.
<template>
<div>
<h1>Benchmark Comparison Results</h1>
<ul>
<li v-for="result in results" :key="result.id">
{{ result.language }}: {{ result.execution_time }} ms ({{
result.date
}})
</li>
</ul>
</div>
</template>
<script>
export default {
test_data() {
return {
results: [],
};
},
mounted() {
fetch("http://localhost:3000/results") // Replace with your API URL if deployed
.then((response) => response.json())
.then((test_data) => {
this.results = test_data.results;
});
},
};
</script>
<template>
<div id="app">
<BenchmarkResults />
</div>
</template>
<script>
import BenchmarkResults from "./components/BenchmarkResults.vue";
export default {
components: {
BenchmarkResults,
},
};
</script>
GitHub Pages serves static files, so we need to build the Vue.JS
project:
npm run build
This will create a dist/
directory with the production files.
To deploy to GitHub Pages, follow these steps:
- Install the
gh-pages
package:
npm install gh-pages --save-dev
- Modify your
package.json
to include a deploy script:
"scripts": {
"deploy": "vue-cli-service build && gh-pages -d dist"
}
- Deploy to GitHub Pages:
npm run deploy
Once complete, you can visit the Benchmarking App at https://<your-github-username>.github.io/<your-repo-name>
.
npm install
npm run serve
npm run build
npm run lint