Comments (4)
To solve #1058, we can use a directory under /tmp
as the $PREFIX
and install the script during test, or run the test in a docker container.
To be frank, I wouldn't say I like to change the project structure as it can be solved by the test suite itself.
from git-extras.
@spacewander Yes, more code could be added to the test suite to handle this. But, what about the other issues I have mentioned? Complexity/fragility of the build system and difficulty of using common functions. The test suite isn't the only place where we see the problems from the build system
from git-extras.
here is a common util.sh file (that we can place in /usr/share/git-extras) that contains all our shared functions. Executables that require it can source it first-thing
As there is no common utility directory for all unix system (Linux, Mac, BSD), and the user can specify the root by using $PREFIX
, move them to a separate file and source it during execution may break the portability and make it harder to manage.
We manually copy and paste these functions for every file. BUT, each function is prefixed with a common prefix (like util_, common_), and we have a check (run at build time and/or commit time) to make sure each function and its contents are identical. Making changes to these functions still isn't too hard because one can simply do a repository-wide find-and-replace in their favorite IDE
The current build process is already guaranteeing the consistency of the utility. To be frank, the check and the find-and-replace could be also complex & fragile.
from git-extras.
I see and understand where you are coming from - there are some disadvantages to my approach as well like the $PREFIX
and moving bin/
files like you mentioned. Thank you for clarrifying your position. Although I may disagree, I will close this issue since you prefer the current approach.
from git-extras.
Related Issues (20)
- Unable to update on Windows HOT 9
- Test(git-authors): add unit test HOT 12
- Create destination folder during `git cp` if it doesn't exist HOT 1
- Allow override temp file location in `git cp` HOT 1
- `find` regex `-iregex '.*\(authors\|contributors\).*'` fails on BSDs
- Time to release 7.1.0 HOT 1
- Refactor(git-authors): support the option `--output` and controlled `--no-email` HOT 1
- Autocompletion after `brew install git-extras` HOT 7
- Discuss: add the python project attribute to git extras repository HOT 6
- git standup recursive search fails if -L missing HOT 1
- It's possible to set up autocompletion after brew install git-extras semi-automatically.
- New git-utimes is broken on Mac HOT 1
- Test(git-browse): unit tests
- Update account security
- Test(git-browse-ci): add unit tests
- Test(git-brv): add unit test
- `git delete-merged-branches` can delete default branch such as `master` HOT 10
- Add a flag to "git delete-squashed-branches" to not abort on first error HOT 3
- Time to release 7.2.0 HOT 3
- [question/feature request] verbose repo summary HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from git-extras.