/sample-to-dataverse

Files uploaded from github

Primary LanguageJavaScriptGNU Affero General Public License v3.0AGPL-3.0

Codemeta Generator

from: https://github.com/codemeta/codemeta-generator

This repository contains a (client-side) web application to generate CodeMeta documents (aka. codemeta.json).

The CodeMeta initiative is a Free and Open Source academic collaboration creating a minimal metadata schema for research software and code.

The academic community recommands on adding a codemeta.json file in the root directory of your repository.

With this linked data metadata file, you can easily declare the authorship, include contextual information and link to other research outputs (publications, data, etc.).

Also, the codemeta.json file in your source code is indexed in the Software Heritage (SWH) archive, which will improve findability in searches.

References

Specifications

Use case

  1. create a complete codemeta.json file from scratch
  2. aggregate existing information and add complementary information to a codemeta.json file

Functionalities

  • helpers while completing the form, for example a reference list of spdx licenses
  • a validation mechanism after submission
  • the possibility to use all the codeMeta terms and schema.org terms
  • accessible from multiple platforms (web browsers or OS)
  • (extra) the possibility to correct the output after validation as part of the creation process

This tool was initially prepared for the FORCE19 Hackathon.

Code contributions.

This section only applies to developers who want to contribute to the Codemeta Generator. If you only want to use it, you can use the hosted version instead.

Code guidelines

This application is designed to work on popular modern browsers (Firefox, Chromium/Google Chrome, Edge, Safari). Check Caniuse for availability of features for these browsers.

To keep the architecture simple, we serve javascript files directly to browsers, without a compiler or transpiler; and do not use third-party dependencies for now.

Running local changes

To run Codemeta Generator, you just need an HTTP server serving the files (nginx, apache2, etc.).

The simplest way is probably to use Python's HTTP server:

git clone https://github.com/codemeta/codemeta-generator
cd codemeta-generator
python3 -m http.server

then open http://localhost:8000/ in your web browser.

Automatic testing

In addition to manual testing, we have automated tests to check for bugs quickly, using Cypress.

To run them, first install Cypress:

sudo apt install npm  # or the equivalent on your system
npm install cypress
$(npm bin)/cypress install

Then, run the tests:

$(npm bin)/cypress run

Contributed by

Image description