The GCS cache plugin can be used to preserve files and directories between builds.
Example
kind: pipeline
name: default
steps:
- name: restore-cache
  image: homerovalle/drone-gcs-cache
  pull: true
  settings:
    bucket: gcs_bucket
    json_key: your-service-account-json-key
    restore: true
- name: build
  image: node
  commands:
  - npm install
- name: rebuild-cache
  image: homerovalle/drone-gcs-cache
  pull: true
  mount:
    - node_modules
  settings:
    bucket: gcs_bucket
    json_key: your-service-account-json-key
    rebuild: true
- name: flush-cache
  image: homerovalle/drone-gcs-cache
  pull: true
  settings:
    bucket: gcs_bucket
    json_key: your-service-account-json-key
    flush: true
    flush_age: 14
Properties
- json_keystringrequired- service account json key. Secret recommended- Default: none 
- restorebooleanoptional- mode to restore the build environment from cache. - Default: false 
- rebuildbooleanoptional- mode to rebuild the cache from the build environment and specified mounts. - Default: false 
- flushbooleanoptional- mode to flush the cache of old cache items (please be sure to set this so we don't waste storage). - Default: false 
- flush_agenumberoptional- flush cache files older then x days. - Default: 30 
- mountarrayoptional- list of files/directories to cache. - Default: none 
- debugbooleanoptional- enabling more logging for debugging. - Default: false 
- filenamestringoptional- filename to use for cache. - Default: none 
- bucketstringrequired- bucket to use to rebuild and restore cache. - Default: none 
- pathstringrequired- path to store the cache file. - Default: [bucket]/<owner>/<repo>/<branch>/ 
- fallback_pathstringrequired- fallback path for the cache file. - Default: [bucket]/<owner>/<repo>/<branch>/ 
- flush_pathstringrequired- path to search for flushable cache files. - Default: [bucket]/<owner>/<repo>/