DAVFoundation / dav-js

Enable integration of JavaScript, TypeScript, and Node.js code with the DAV Network
https://developers.dav.network/
MIT License
75 stars 50 forks source link

Update the constructor in `src/drone-delivery/NeedParams.ts` and add Jest tests for `src/drone-delivery/NeedParams.ts` #110

Closed mariolo1985 closed 5 years ago

mariolo1985 commented 5 years ago

first-timers-only

This issue is tagged 🕺 first-timers-only. It is only for people who have never contributed to open source before, and are looking for an easy way take their first steps.

Consider this your chance to dip your toe into the world of open-source, and get some bragging rights for writing code that makes drones fly, lets cars find charging stations, helps people and goods get from place to place, and more.

Find more first-timers-only issues from DAV Foundation here.

Thank you for your help :heart:

What is this project?

DAV (Decentralized Autonomous Vehicles) is a new foundation working to build an open-source infrastructure for autonomous vehicles (cars, drones, trucks, robots, and all the service providers around them) to communicate and transact with each other over blockchain.

As an organization that believes in building a large community of open-source contributors, we often create issues like this one to help people take their first few steps into the world of open source.

dav-js

This repo contains the DAV JavaScript SDK. This SDK allows developers to build applications and servers that connect to the DAV network. For example, allowing a drone to find charging stations, or an autonomous car to ask for traffic data.

How you can help

In order to foster a community that is welcoming for open source contributions, it is important for us to have good test coverage. And good tests are simple, readable tests.

Here is a good opportunity to update one of our tests.

The Issue

In the src/drone-delivery/NeedParams.ts class, the constructor is not defining the startLocation and endLocation objects correctly. Currently, the long key is set to the lat value.

      this.startLocation = {
        lat: values.startLocation.lat,
        long: values.startLocation.lat,
      };
      this.endLocation = {
        lat: values.endLocation.lat,
        long: values.endLocation.lat,
      };

The Updates

Please update the constructor in src/drone-delivery/NeedParams.ts by defining the startLocation and endLocation objects correctly.

Please create Jest tests for src/drone-delivery/NeedParams.ts

1. Update the constructor

Update the constructor by defining the startLocation and endLocation objects with the associated lat and long values.

The end result will be similar to this:

      this.startLocation = {
        lat: values.startLocation.lat,
        long: values.startLocation.long,
      };
      this.endLocation = {
        lat: values.endLocation.lat,
        long: values.endLocation.long,
      };

2. Create Jest tests

We currently do not have unit testing set up for src/drone-delivery/NeedParams.ts. Please create Jest tests for the serialize() and deserialize() methods.

A good reference point would be src/ride-hailing/MissionParams.test.ts and customize it to the expected parameters and properties. If you are unsure what is expected, run npm run jest in the terminal and it should give you a hint. Also, you can reach out to our gitter channel with any questions 😄

The test you write will be similar to this:

import NeedParams from './NeedParams';
import VehicleTypes from './VehicleTypes';

describe('NeedParams class', () => {
  let needParams: NeedParams;
  let serializedNeedParams: any;

  beforeEach(() => {
    needParams = new NeedParams({
      endLocation: {
        lat: 32.050382,
        long: 34.766149,
      },
      location: {
        lat: 32.050382,
        long: 34.766149,
      },
      maxAltitude: 6000,
      startAt: undefined,
      startLocation: {
        lat: 32.050382,
        long: 34.766149,
      },
      vehicleType: VehicleTypes.drone
    });

    serializedNeedParams = {
      davId: undefined,
      endLocation: {
        lat: 32.050382,
        long: 34.766149,
      },
      id: undefined,
      location: {
        latitude: 32.050382,
        longitude: 34.766149,
      },
      maxAltitude: 6000,
      protocol: 'drone_delivery',
      startLocation: {
        lat: 32.050382,
        long: 34.766149,
      },
      type: 'need',
      ttl: undefined,
      vehicleType: VehicleTypes.drone
    };
  });

  describe('serialize method', () => {
    it('should return serialized NeedParams object with the current values', () => {
      expect(needParams.serialize()).toEqual(serializedNeedParams);
    });
  });

  describe('deserialize method', () => {
    it('should return a NeedParams instance', () => {
      const needParamsObject = new NeedParams();
      needParamsObject.deserialize(serializedNeedParams);
      expect(needParamsObject).toBeInstanceOf(NeedParams);
    });

    it('should return deserialize NeedParams instance with current parameters', () => {
      const needParamsObject = new NeedParams();
      needParamsObject.deserialize(serializedNeedParams);
      expect(needParamsObject).toEqual(needParams);
    });
  });
});

After making your changes, run npm run tslint and npm run jest to make sure our tests are passing.

Contributing to dav-js

Asking for help

We appreciate your effort in taking the time to work on this issue and help out the open source community and the foundation. If you need any help, feel free to ask below or in our gitter channel. We are always happy to help 😄

AyoAlfonso commented 5 years ago

Hello @mariolo1985 Can I claim this issue and start working on it right away?

mariolo1985 commented 5 years ago

Hi @AyoAlfonso yes you can start working on it :+1: Thank you!

mariolo1985 commented 5 years ago

Hi @AyoAlfonso are you still interested in working on this issue?

gfting commented 5 years ago

Hello! I'm interested in working on this issue if @AyoAlfonso is not working on this still. @mariolo1985

gfting commented 5 years ago

@mariolo1985 I went ahead and forked it and made sufficient changes so that it passed npm run jest and npm run tslint; can I go ahead and send in a PR since they haven't fixed the issue in a few months? Thanks!

AyoAlfonso commented 5 years ago

Hi @gfting! I could not work on the issue, I think you can go ahead and make your PR.

TalAter commented 5 years ago

Thank you @gfting, pull request looks great 👍