Skip to content

Commit

Permalink
Merge pull request #16 from oslabs-beta/mma/debug
Browse files Browse the repository at this point in the history
docs: updated dev readme to include roadmap info, deleted roadmap
  • Loading branch information
misterjoecool authored Jun 5, 2024
2 parents 4c1a24b + 699a22b commit b4d9795
Show file tree
Hide file tree
Showing 3 changed files with 119 additions and 141 deletions.
148 changes: 107 additions & 41 deletions DEV_README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,85 +13,151 @@
<p><b> WHAT YOU NEED TO DO FIRST: </b></p>

Run npm run dev twice if you do not manually run tsc to compile the files first. The ts files have to compile before electron-dev and webpack-dev can start.<br>
<code>npm run install</code><br>
<code>npm run postinstall</code><br>
<code>npm run build</code><br>
<code>npm run dev</code> or <code>npm run start</code>(this is more stable but no hot module reloading)
`npm run install`<br>
`npm run postinstall`<br>
`npm run build`<br>
`npm run dev` or `npm run start` ( this is more stable but no hot module reloading)

- Mac vs Windows:

In the '../backend/src/models/configModel.ts' on line 9 - 11 specifies where the configFile will be downloaded. The 'home' variable will be different for Mac and Windows users. Utilize an if conditional statement here to prevent the need for maintaining two branches (main and devosx) for windows and mac.

- For Windows set `home = process.cwd()` on line 9;
- For Mac set `home = ${os.homedir()}/Documents/SeeQR` on line 9.

<p><b> WHAT WE UPDATED: </b></p>

<p>1. Refactored UI to enhance user's experience by improving readability and predictability.</p>
<p>2. Updated deprecated or unsupported dependencies and fixed breaking changes to ensure application remains easy to maintain and improve. <br>
- NOTE: DO NOT UPDATE the “fixPath” PACKAGE! It will break the app. </p>
<p>3. Started the migration from Context API to Redux Toolkit for state management, ensuring future scaling and maintainability. <br>
- Three slices have been created to replace old reducers.</p>
<p>2. Updated deprecated or unsupported dependencies and fixed breaking changes to ensure application remains easy to maintain and improve.</p>

- NOTE: DO NOT UPDATE the “fixPath” PACKAGE! It will break the app.
<p>3. Started the migration from Context API to Redux Toolkit for state management, ensuring future scaling and maintainability. </p>

- Three slices have been created to replace old reducers.
<p>4. Fixed Database Authentication for MySql, Postgres, RDS MySql and RDS Postgres.</p>
<p>5. Added additional testing suites to improve the tests coverage.</p>
<p>6. Enforced Typescript typing where it was missing.</p>
<p>7. Moved all reusable types into one location to prevent duplication.</p>

<p><b> WHAT NEEDS TO BE DONE: </b></p>

<p> 1. Finishing the migration of state management to Redux Toolkit. <br>Context API is not a good way to manage state in an increasingly complex app. </p>
<p> 1. Finishing the migration of state management to Redux Toolkit.</p>

- Context API is not a good way to manage state in an increasingly complex app.
<p> 2. New testing for the Redux frontend. Improve test coverage overall for the rest of the application. </p>
<p> 3. There needs to be a continuous audit for old deprecated code. Things like “event” are deprecated for ‘e’ in React and some files are still using old code since we did not get to audit it. </p>
<p> 3. There needs to be a continuous audit for old deprecated code.</p>

- Things like “event” are deprecated for ‘e’ in React and some files are still using old code since we did not get to audit it.
<p> 4. Typescript needs to be enforced. There are certain parts of the codebase that do not use Typescript typing and it should be rectified with refactoring. </p>
<p> 5. Old code is commented out. Some files contain a lot of commented out code which need to be addressed by either deleting or fixing the issues with it.
<p> 6. If it is 12/2024 or after Electron has probably ended support for version 30 of Electron and an update will need to be done. </p>
<p> 7. Since the dependency update some MUI components have outdated props that will have to be changed </p>
<p> 8. As migration of Redux is complete old files need to be deleted from state management. (comparing total old file size to new file size could be a good metric)</p>
<p> 9. ESLint config should be migrated to an es.config.js file (Low priority)</p>
<p> 7. Since the dependency update some MUI components have outdated props that will have to be changed. </p>
<p> 8. As migration of Redux is complete old files need to be deleted from state management. (comparing total old file size to new file size could be a good metric).</p>
<p> 9. ESLint config should be migrated to an es.config.js file (Low priority).</p>

<p>10. Refactor tableTabBar Component</p>

<p>10. Refactor tableTabBar Component<br>
- Migrated ERTabling to tableTabBar component to access the ERD because it lacked a parent compartment for prop drilling, hindering the addition of new features. Going forward, a more maintainable solution should be implemented like Redux or Zustand.
</p>

<p>11. Isolating Database<br> One of the biggest tasks that we tried but <b>did not finish</b> is isolating the concerns of each database type (DBType). The current application has multiple</p>
<code>if (database === DBType.postgres) {}<br>
else if (database === DBType.mysql) {}<br>
else (database === DBType.sqlite) {}<br>
</code>
<br>
<p>situations and it is not good. instead we will use switch statements to preemptively throw operations into separate functions to completely silo cases for Postgres, Mysql, and SqLite. This is a task for <b>BOTH THE FRONTEND AND BACKEND</b> and the <b>FRONTEND IS MUCH HARDER</b>. The work for backend is actually done and it is illustrated in the picture below </p>
<p>11. Isolating Database</p>

- One of the biggest tasks that we tried but <b>did not finish</b> is isolating the concerns of each database type (DBType). The current application has multiple</p>
<code>if (database === DBType.postgres) {}<br>
else if (database === DBType.mysql) {}<br>
else (database === DBType.sqlite) {}<br>
</code>situations and it is not good. Instead we will use switch statements to preemptively throw operations into separate functions to completely silo cases for Postgres, Mysql, and SqLite. This is a task for <b>BOTH THE FRONTEND AND BACKEND</b> and the <b>FRONTEND IS MUCH HARDER</b>. The work for backend is actually done and it is illustrated in the picture below.

<img src="./assets/readmeImages/erdArchitecture.png" height=500/>

<p>The road map is finish connecting the siloed pieces for postgres, then moving on to mysql <br><br> <b>***Important*** <br> There is no entry for this system yet, but this file frontend/components/iews/ERTables/ERDisplayWindow.tsx will be the entry once completed</b></p>
<p>The road map is finish connecting the siloed pieces for postgres, then moving on to mysql <br><br> <b>***Important*** <br> There is no entry for this system yet, but this file frontend/components/iews/ERTables/ERDisplayWindow.tsx will be the entry once completed.</b></p>

<p>12. ERD Logic Update<br>Currently, previous wrote the frontend to send back a big bundle of all the operations done in the frontend ERD Table. This ERD table object is divided by add, drop, and alter. All the add operations will execute first then drop, then alter. This is <b>BAD</b>. <br><br> We need to redesign frontend to send back "sequental" operations instead of bundling operations by add, drop, alter because it takes care of multiple edge cases and users in the front can do as many operations they want to ensure <b>SAVE</b> works. I illustrated the problem below. The current backend is written out already. We just need to make sure the frontend is send back the appropriate logic</p>
<p>12. ERD Logic Update</p>

- Currently, previous wrote the frontend to send back a big bundle of all the operations done in the frontend ERD Table. This ERD table object is divided by add, drop, and alter. All the add operations will execute first then drop, then alter. This is <b>BAD</b>.
- We need to redesign frontend to send back "sequental" operations instead of bundling operations by add, drop, alter because it takes care of multiple edge cases and users in the front can do as many operations they want to ensure <b>SAVE</b> works. I illustrated the problem below. The current backend is written out already. We just need to make sure the frontend is send back the appropriate logic.</p>

<img src="./assets/readmeImages/ERD_before_after.png" height=500/>

<br><br> <b>**_Important_** <br> This is written at backend/src/ipcHandlers/dbCRUDHandlerERD.ts and will replace backend/src/ipcHandlers/dbCRUDHandler.ts when this is ready</b>
<br><br> <b>**_Important_** <br> This is written at `backend/src/ipcHandlers/dbCRUDHandlerERD.ts` and will replace `backend/src/ipcHandlers/dbCRUDHandler.ts` when this is ready</b>

<p>13. Async event emmiters between front/backend</p>
<p>Currently, the way the feedback modal works is by handling events that are emitted from both the frontend and the backend. Ideally, this should be refactored to be state dependent rather than event dependent, as it controls the display of the modal. This can be tied into the centralized async event emitter added to frontend/components/app.tsx, in conjunction with migration to reducers from state variables. The goal will be to house modal messages in the store tied to the main app reducer. From there, the async handler can send new messages to the state via main app dispatch, and any other front end feedback can do the same.<br><br>
The main roadblock in the way of finalizing the transfer of event handlers out of the frontend is the way the dblist (list of databases in the sidebar) gets updated. Many event handlers in the backend send a dblist update event out to update the front end. Ideally, this should be handled by returning the new dblist changes out of the handler and using that resolved value to update state whenever an action would cause a dblist change. Right now, app.tsx has a useEffect running that listens for those dblist updates every frame. This is inefficient as a frontend concern.<br><br>
The spinner currently works in a similar way to feedback. Once all async is completely migrated (including dblist update changes), this spinner can simply be tied to the loading property in the main app state.<br><br>
There are still some filesystem read/write calls in the front end. This should be refactored to an async call that requests the backend handle the file system read/write for proper separation of concerns.
</p>

- Currently, the way the feedback modal works is by handling events that are emitted from both the frontend and the backend. Ideally, this should be refactored to be state dependent rather than event dependent, as it controls the display of the modal. This can be tied into the centralized async event emitter added to frontend/components/app.tsx, in conjunction with migration to reducers from state variables. The goal will be to house modal messages in the store tied to the main app reducer. From there, the async handler can send new messages to the state via main app dispatch, and any other front end feedback can do the same.
- The main roadblock in the way of finalizing the transfer of event handlers out of the frontend is the way the dblist (list of databases in the sidebar) gets updated. Many event handlers in the backend send a dblist update event out to update the front end. Ideally, this should be handled by returning the new dblist changes out of the handler and using that resolved value to update state whenever an action would cause a dblist change. Right now, app.tsx has a useEffect running that listens for those dblist updates every frame. This is inefficient as a frontend concern.
- The spinner currently works in a similar way to feedback. Once all async is completely migrated (including dblist update changes), this spinner can simply be tied to the loading property in the main app state.
- There are still some filesystem read/write calls in the front end. This should be refactored to an async call that requests the backend handle the file system read/write for proper separation of concerns.

<p>14. Update UI of the initial landing page of application with cloud database instructions.</p>
<p>15. Support for amazon aurora (beware of billing).</p>
<p>16. Work on explain function for mysql and sqlite, may have different metadata from existing postgres implementation, display whatever you can get. </p>
<p> 17. Set up RDS pg cloud queries</p>

- RDS my sql cloud queries wont let you create multiple tables at once. as in you have to create one table, then make another query to make your second table.

- When you create a new cloud pg database, it seems to have all the other databases tables as well.
<p>18. 3D visualization refactoring</p>

- Change the way the 3D page is rendered, to allow switching directly between different databases through the sidebar (currently you need to leave the 3D page before switching to a new database).

- Make the camera auto rotate when initially opening the 3D page.

- Better cache/memory management to speed up animations/rendering.

- Make the green table in the 3D view always face the user's camera.

- Implement ER table functions.

<p><b> WHAT IS BROKEN: </b></p>

<p>1. The application on Windows may periodically crash.</p>
<p>2. There are import issues on Mac computers.</p>
<p>2. Database Management </p>

- Unable to import pg or mySQL database files
<p>4. Cannot currently make a new Query, selecting queries from a database view will crash the application.</p>
<p>4a. Duplicates appear on previous queries.</p>
- Currently postgres imports/duplicates only works for either windows.
- Perhaps use `.pgpass` file instead of pgpassword environment variable for security (for postgresql imports/duplicates)
- Found in `backend/helperFunctions.ts`.
- Fix importing MySQL databases (currently creating an extra hollow copy or not working at all).
- Currently importing MySQL databases will work when only MySQL server is up on MAC OS.
- MySQL databases that are imported will only show data type, but not column name.
- Fix sqlite and RDS databases (currently only Postgres and MySQL are working).
- SQLite was never fully implemented as a supported database and is currently only a copy of PSQL.

- In 'queryView', the 'queriesRan' state is defined, set, and passed down as a prop to its child component 'queryHistory'. On line 54 of 'queryHistory', duplicate query saved in the queriesRan state are removed. However, there's a problem: when we click the format button in QuerySqlInput and then run the query, it saves the query again. This happens because the new Set method doesn't recognize the formatted SQL strings due to the presence of '\n' characters. Consequently, clicking the run query button for both unformatted and formatted SQL strings results in duplicates being saved in the query history.
<p>3. Devtools do not currently work with Electron due to Manifest V2 being deprecated by Chrome and no update by Electron to support Manifest V3. Built in chrome devtool only thing available.</p>

<p>5. SQLite was never fully implemented as a supported database and is currently only a copy of PSQL</p>
<p>6. Column manipulation is not working in the application (adding, modifying, deleting etc.). We expect the <br>
migration to Redux may have changed things unexpectedly or other code was never finished. Reference v11 for working code.</p>
<p>7. Devtools do not currently work with Electron due to Manifest V2 being deprecated by Chrome and no update by Electron to <br>
support Manifest V3. Built in chrome devtool only thing available.</p>
<p>8. Label and Group field disappears.</p>
<p>4. Label and Group field disappears.</p>

- In the queries tab, the Label and Group text in input field will disappear when selecting the Monaco Editor.
- The bug may arise from the useEffect hook, which triggers every time the component updates. Any changes detected in the editor results in a new Monaco Editor instance, potentially resetting the label and group text inputs.

<p>9. Foreign and Primary keys.</p>
<p>5. Foreign and Primary keys.</p>

- Unable to select the primary and/or foreign key of a newly added column until the column is saved onto the database. Once saved onto the database, we can then select the primary and foreign key and save them onto the database.

<p> 6. Queries page </p>

- Fix query execution plan table view, likely broke while updating frontend dependencies.

- Utilize local storage to save query history. Currently the history disappears when we reload application.
- Cannot currently make a new Query, selecting queries from a database view will crash the application.
- Duplicates appear on previous queries.

- In 'queryView', the 'queriesRan' state is defined, set, and passed down as a prop to its child component 'queryHistory'. On line 54 of 'queryHistory', duplicate query saved in the queriesRan state are removed. However, there's a problem: when we click the format button in QuerySqlInput and then run the query, it saves the query again. This happens because the new Set method doesn't recognize the formatted SQL strings due to the presence of '\n' characters. Consequently, clicking the run query button for both unformatted and formatted SQL strings results in duplicates being saved in the query history.

<p> 7. 2D visualization / ER tables </p>

- Fix react flow bugs (tables moving on save, weird auto zooming, etc), maybe rewrite layout save functionality.

- Fix bugs for MySQL and SQLite (they work differently from PostgreSQL which is the basis for all current ERtable functionality).

- i.e. SQLite doesn't support changing column names/data types after building them, but the ERtable currently creates columns and then alters them on the backend.

- Column manipulation is not working in the application (adding, modifying, deleting etc.). We expect the
migration to Redux may have changed things unexpectedly or other code was never finished. Reference v11 for working code.

- Fix the occasional bug with selecting.

- queued backendObj changes are still there even when switching between different dbs in sidebar.

- account for different constraint naming conventions (mostly mysql).

- Resolve issue of creating additional columns for each constraint (mostly mysql).
Loading

0 comments on commit b4d9795

Please sign in to comment.