-
Notifications
You must be signed in to change notification settings - Fork 0
Project 3 Report
Our problem statement focused on the previous scenario of MFT, which only had support for 3 protocols namely SCP, Local, and S3. Moreover, the system was not a standalone system, as it required service to integrate with MFT rather than a user directly talking to it. Furthermore, it was not deployed in a distributed environment to enable better scalability and fault tolerance.
Initially, when we started, we aimed at making MFT a standalone system and add new transport provider support to the project. We did look into the design of the project and how it could be extended to be deployed in the cloud environment. However, since multiple teams were focusing on the same problem, we decided to focus on adding new protocol support, testing, and henceforth finding issues in the quickly evolving environment of MFT.
Furthermore, we identified several bugs and reported them to the Airavata community in order to make the project more robust and reliable. We did look into the design of the project and how it could be extended to be deployed in the cloud environment. However, since multiple teams were focusing on the same problem, we decided to direct our focus on adding new protocol support, testing, and henceforth finding issues in the quickly evolving environment of MFT.
We regularly communicated with the Airavata developer community regarding doubts about our contributions and also reporting the issues we found with the existing codebase. The following are the links to the communication between the pika-pika team and the developer community.
- https://lists.apache.org/thread.html/rab4f83ef4edbe105bcaf6db334146529ddc7850445b93a4d3093a445%40%3Cdev.airavata.apache.org%3E
- https://lists.apache.org/thread.html/r74e8ecb2a7f9e7b57404858da790dd81df8e2037c6e959e0d6d03cdf%40%3Cdev.airavata.apache.org%3E
- https://lists.apache.org/thread.html/rc0fadd042b9d604e1130feb29ee6c8afd591b20e2978e612717f3e0f%40%3Cdev.airavata.apache.org%3E
- https://lists.apache.org/thread.html/r38ff4fb7fed5fff9b4373d1ec7b80fe94df52befb819a8505041f25a%40%3Cdev.airavata.apache.org%3E
- https://lists.apache.org/thread.html/r907c04e56ade0db2fdf0bb532676555bac2394071db49e1604c0a720%40%3Cdev.airavata.apache.org%3E
- https://lists.apache.org/thread.html/rd7c21f388be5404b77fb56398dacca47afca3de1b37db165b5d8a6da%40%3Cdev.airavata.apache.org%3E
- https://lists.apache.org/thread.html/r6564088c48d20b556be95b930dd1cab946dc8ba073cd445a8f2c9a70%40%3Cdev.airavata.apache.org%3E
- https://lists.apache.org/thread.html/ra5c9c440a14cc9b6134f3261447e52390d0d7c9dfe93338141e708f7%40%3Cdev.airavata.apache.org%3E
Due to the prompt response of the developer community, we were able to successfully make contributions in the project.
-
We started with understanding the codebase and testing the existing transport protocols. We were able to achieve this mailing in the apache dev community and eventually by setting up the project in our local development environment.
-
We had a look at the previous contributions to the project to get an understanding of the changes required to integrate a new transport protocol.
-
We gathered information about the API regarding the parameters to transfer files to and from the transport storage provider. These parameters included factors such as authentication token, credentials file, bucket name, etc.
-
Finally, we implemented the necessary changes and created a pull request for the moderators to review the code.
-
We started by forking the original repository and set up an upstream to stay on to date with the latest updates.
-
Then, we added an api-gateway service to interact with the existing MFT system to enable us to make RPC communication with the MFT API service application.
-
We added a new transport module to create the relevant implementations for Sender, Receiver, and MetadataCollector of the corresponding storage provider namely GCS and Dropbox.
-
We extended the resources and secret proto files on the basis of the authentication method requirements and the resource details required by the storage provider.
-
We then added the relevant methods to the resource and secret backend that were required to support our implementation.
-
Finally, we tested the code integration by testing file transfer between our newly implemented transport and the existing ones.
We also contributed to the design document that elaborates further on how to integrate a new transport with the MFT project.
Design Document for MFT transport
We evaluated the problem by testing our implementation by transferring to and fro between our newly integrated transport with the existing protocols. This way, we ensure that we integrate our code without bringing any new issues into the existing codebase and have integration testing in the process.
What did you conclude based on your evaluations? How do you objectively substantiate your conclusions? Negative conclusions are acceptable if properly substantiated.
Summarize what each team member contributed. Each team member should list git commits, issues, pull requests, and discussion list posts to substantiate effort.
<... API gateway work for testing the working of MFT and which was used by fellow classmates to get a better insight into the project. Also mention the standalone factor here....>
< Add the initial README issues? because of no initial documentation, we had to put in a lot of time to getting started with the existing system and the overall investigation too.>
Hence, we provided support for Dropbox transport and identified a qualitative issue with file transfer in the mft-core module. We also worked with the Airavata developer community to create a design document to give developers a good understanding of how to add a new transport provider support to MFT.